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

原题链接:[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;
}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值