Topcoder SRM 683 Div2 B

贪心的题,从左向右推过去即可

#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;
}
posted @ 2016-03-03 15:20  一骑绝尘去  阅读(132)  评论(0编辑  收藏  举报