未知题目 随笔 第1张

 

SRE实战 互联网时代守护先锋,助力企业售后服务体系运筹帷幄!一键直达领取阿里云限量特价优惠。

这个题有一些数学思维在里面,记住x[i]表示a[i+1]给a[i]拿的个数, 然后推公式

 

未知题目 随笔 第2张

 

代码:

#include<iostream>
#include<cmath>
#include<algorithm>
using namespace std;
#define ll long long
const int maxn=1e6+10;
ll a[maxn],sum, aa, ans;
int n;

int main()
{
    cin>>n;
    for (int i=1;i<=n;i++) {cin>>a[i];sum+=a[i];}
    sum/=n;
    a[1]=sum-a[1];
    for (int i=2;i<=n;i++){
        aa=sum-a[i];
        a[i]=a[i-1]+aa;
    }
    sort(a+1,a+n+1);
    aa=a[n/2+1];
    for (int i=1;i<=n;i++) ans+=abs(aa-a[i]);
    cout<<ans<<endl;
}

 

扫码关注我们
微信号:SRE实战
拒绝背锅 运筹帷幄