【枚举+sorting+递推(DS思想)】 ABC186 D - Sum of difference

61 篇文章 0 订阅
27 篇文章 0 订阅

一发过!

有点CF的感觉

D - Sum of difference (atcoder.jp)

题意:

思路:

O(n^2)超时,肯定是O(n)算

因为算的是所有对的贡献,因此数列是无序的

因此可以把数列排个序

然后注意到相邻两个数的贡献是可以递推的,比较相邻两个数的贡献即可

 

 

Code:

#include <bits/stdc++.h>

#define int long long
#define max(a,b) (a>b?a:b)
#define min(a,b) (a<b?a:b)

using namespace std;

const int mxn=2e5+10;
const int mxe=3e5+10;
const int mod=1e9+7;
const int Inf=1e18;

int N;
int a[mxn],F[mxn];

void solve(){
    cin>>N;
    for(int i=1;i<=N;i++) cin>>a[i];
    sort(a+1,a+1+N);
    for(int i=2;i<=N;i++) F[1]+=a[i]-a[1];
    for(int i=2;i<=N;i++){
        F[i]=F[i-1]-a[i]-a[i]*(N-i)+a[i-1]*(N-(i-1));
    }
    //for(int i=1;i<=N;i++) cout<<F[i]<<" \n"[i==N];
    int ans=0;
    for(int i=1;i<=N;i++) ans+=F[i];
    cout<<ans<<'\n';
}
signed main(){
    ios::sync_with_stdio(0), cin.tie(0), cout.tie(0);
    int __=1;//cin>>__;
    while(__--)solve();return 0;
}

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
根据提供的引用内容,稳定排序算法是指在排序过程中,具有相等键值的元素在排序后的顺序保持不变。根据这个定义,稳定排序算法有Bucketsort和Mergesort。Bucketsort是稳定的排序算法,因为它将元素放入不同的桶中,并在每个桶内进行排序,保持了相等键值元素的相对顺序。Mergesort也是稳定的排序算法,因为它通过将数组分成两个子数组并递归地对它们进行排序,然后将它们合并来完成排序,保持了相等键值元素的相对顺序。而Heapsort和Quicksort不是稳定的排序算法,因为它们在排序过程中可能会交换相等键值的元素的位置,导致相等键值元素的相对顺序发生改变。所以,答案是Bucketsort和Mergesort。 #### 引用[.reference_title] - *1* *2* [常见排序算法比较 Comparison of different sorting algorithms](https://blog.csdn.net/weixin_45561634/article/details/104238225)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^control,239^v3^insert_chatgpt"}} ] [.reference_item] - *3* [Java - Sorting Algorithms](https://blog.csdn.net/weixin_39824834/article/details/114503063)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^control,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值