codeforces 675C Money Transfers 贪心

题目链接:http://www.codeforces.com/problemset/problem/675/C

题意:

有n个银行,每个银行有一个账户,账上的钱可能为负或正或0,且n个银行账户的钱和为0,两个相邻银行的账户可以互相转账,1和n也可以,相当于一个圈。

求最少转多少次可使每个账户上的钱都变成0。

 

思路:

很明显最多转n-1次就可以满足要求了,即随便选一个点,把每个点的值依次加到下一个点,直到该点的前一个点。

那么假如中间有一段和为0的,假如长度为l,那么次数只要l-1,所以每多一个这样的段总数就可以减少1。

那么就是找出最多的中间和为0的段的数量就可以了。

 1 #include <bits/stdc++.h>
 2 using namespace std;
 3 int n;
 4 int a[100010];
 5 long long sum;
 6 int main() 
 7 {
 8   //  freopen("in.txt", "r", stdin);
 9   //  freopen("out.txt", "w", stdout);
10     while(~scanf("%d", &n))
11     {
12         sum = 0;
13         for(int i = 1; i <= n; i++) scanf("%d", &a[i]);
14 
15         map <long long, int> mp;
16         mp[0] = 1;
17         int ans = 1;
18         for(int i = 1; i < n; i++)
19         {
20             sum += a[i];
21             mp[sum]++;
22             if(mp[sum] >= ans) ans = mp[sum];
23         }
24         printf("%d\n", n-ans);
25     }
26     return 0;
27 }

 

posted @ 2016-05-18 21:59  下周LGD该赢了吧  阅读(460)  评论(0编辑  收藏  举报