[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
题意分析:翻转一个区间,使得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; }
相关文章推荐
- Codeforces 327A Flipping Game(区间DP,暴力枚举)
- Codeforces 327A-Flipping Game(暴力枚举)
- Codeforces 327A-Flipping Game(暴力枚举)
- Code Forces 327A - Flipping Game 贪心 暴力
- hdu_5693_D Game(区间DP)
- Codeforces Round #191 (Div. 2)---A. Flipping Game
- 例题28 UVa10891 Game of Sum(DP)
- Codeforces #191(Div.2)-A. Flipping Game
- [BZOJ2318][SPOJ4060]Game with probability Problem 概率DP
- [树形DP 暴力] BZOJ 3696 化合物
- UVALive 6919 A game for kids(树形dp)
- 【hdu 5945 】 【dp+单调队列优化】Fxx and game【求数x最少经过多少次变换能变为1,(1)如果x%k==0,那么可以x=x/k。(2)x=x-i,(1<=i<=t)】
- 【HDU 5945】Fxx and game(DP+单调队列)
- Codeforces Round #336 (Div. 2)B 暴力 C dp D 区间dp
- Codeforces6D(暴力dp)
- Codeforces Round #367 (Div. 2) A(暴力) B(二分查找) C(DP) D(01字典树)
- ZOJ-3593 One Person Game 概率DP
- HDU 5945 Fxx and game(dp+单调队列优化)
- Codeforces Round #336 (Div. 2)【A.思维,暴力,B.字符串,暴搜,前缀和,C.暴力,D,区间dp,E,字符串,数学】
- Codeforces 280C Game on Tree 树形期望dp