码迷,mamicode.com
首页 > 其他好文 > 详细

分金币 (UVA 11300)

时间:2015-09-10 00:17:47      阅读:251      评论:0      收藏:0      [点我收藏+]

标签:

http://acm.hust.edu.cn/vjudge/problem/viewProblem.action?id=33899

 

思路:推公式,发现可以转化为求给定n个数,求到所有点距离之和最小的点的问题

 

技术分享
#include <iostream>
#include <algorithm>
#include <cstdio>
#include <cmath>
#define RPE(i,n) for(int i=1;i<=(n);i++)
typedef long long LL;
const int maxn=1e6+10;
LL a[maxn],c[maxn];
using namespace std;
int main()
{
    ios::sync_with_stdio(false);
    int n,ca=1;
    while(cin>>n)
    {
        LL sum=0;
        RPE(i,n)
        {
         cin>>a[i];
         sum+=a[i];
        }
        LL m=sum/n;
        c[1]=0;
        RPE(i,n)
        {
            c[i]=c[i-1]-(a[i]-m);
        }

        sort(c+1,c+n+1);

        LL ans=0;

        RPE(i,n) ans+=abs(c[i]-c[n/2]);

        cout<<ans<<endl;
    }
    return 0;
}
View Code

 

分金币 (UVA 11300)

标签:

原文地址:http://www.cnblogs.com/zsyacm666666/p/4796271.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!