您的位置:首页 > 其它

[CodeForces327A]Flipping Game[dp][暴力]

2015-05-24 11:29 288 查看
原题链接:[CodeForces327A]Flipping Game[dp][暴力]

题意分析:翻转一个区间,使得1的个数最多。(必须翻转一次!)

解题思路:可暴力,可dp。暴力的话,遍历每个区间段,小区间内的1个数 = 小区间长度 - 小区间内1的个数。小区间外1个数 = 大区间1个数 - 小区间内1个数。然后每次更新。

dp的话,就是求出最大区间0的个数(这个区间中1的影响为-1,0的影响为1),然后加上所有1个数就是最终答案了。

个人感受:dp还是弱弱啊。。。。暴力也没怎么去想,唉。。。。

具体代码如下:仅提供dp版本XD

#include <iostream>
#include <string>
#include <algorithm>
using namespace std;

int main()
{
    int n, x, mx = 0;
    cin >> n;
    int cnt0 = 0, cnt1 = 0;
    for (int i = 0; i < n; ++i)
    {
        cin >> x;
        if (x == 1) ++cnt1; //整个区间中1的个数
        if (x == 0)
        {
            ++cnt0;
            if (cnt0 > mx)  //翻转区间所得最多1的个数
                mx = cnt0;
        }
        else if (cnt0) --cnt0; //1的值对cnt0的取值影响为-1
    }
    if (mx == 0) --mx; //没有0,那么至少也要翻一次
    cout << mx + cnt1 << '\n';
    return 0;
}
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: