您的位置:首页 > 运维架构

Topcoder SRM 683 Div2 B

2016-03-03 15:20 357 查看
贪心的题,从左向右推过去即可

#include <vector>
#include <list>
#include <map>
#include <set>
#include <deque>
#include <stack>
#include <bitset>
#include <algorithm>
#include <functional>
#include <numeric>
#include <utility>
#include <sstream>
#include <iostream>
#include <iomanip>
#include <cstdio>
#include <cmath>
#include <cstdlib>
#include <ctime>

using namespace std;

class MoveStonesEasy {
public:
int get(vector <int>, vector <int>);
};

int MoveStonesEasy::get(vector <int> a, vector <int> b)
{
int sum1 = 0,sum2 = 0;

for(int i = 0; i < a.size() ; i++)
{
sum1 += a[i];

sum2 += b[i];
}

if(sum1!=sum2)
{
return -1;
}
sum1 = 0;
for(int i = 0; i<a.size();i++)
{
if(a[i]<b[i])
{
sum1+=(b[i]-a[i]);

a[i+1] -=(b[i]-a[i]);
}
else if(a[i]>b[i])
{
sum1+=(a[i]-b[i]);

a[i+1]+=(a[i]-b[i]);
}
}

return sum1;
}
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: