题目链接

给你一串只有0和1的数字,然后对某一区间的数翻转1次(0变1 1变0),只翻转一次而且不能不翻转,然后让你计算最多可能出现多少个1。

这里要注意很多细节 比如全为1,要求必须翻转,这时候我们只要翻转一个1就可以了,对于其他情况,我们只要计算区间里面如果0多于1,将其翻转后计算1的总数,然后取最大值。

//cf 191 A
//2013-07-04-22.13
#include <stdio.h>
#include <string.h>
#include <algorithm>
using namespace std;
int a[105]; int cnt[105]; int main()
{
int n;
while (scanf("%d", &n) != EOF)
{
int sum = 0;
memset(cnt, 0, sizeof(cnt));
for (int i = 1; i <= n; i++)
{
scanf("%d", &a[i]);
if (a[i] == 0)
{
cnt[i] = cnt[i-1] + 1;
}
else
{
cnt[i] = cnt[i-1];
sum++;
}
}
if (sum == n)
{
printf("%d\n", sum - 1);
continue;
}
if (sum == n-1)
{
printf("%d\n", n);
continue;
}
int ans = sum + 1;
for (int i = 2; i <= n; i++)
{
for (int j = 1; j < i; j++)
{
if ((cnt[i] - cnt[j-1]) > ((i-j+1) - (cnt[i] - cnt[j-1])))
ans = max (ans, sum - ((i-j+1) - (cnt[i] - cnt[j-1])) + (cnt[i] - cnt[j-1]));
}
}
printf("%d\n", ans);
}
return 0;
}

最新文章

  1. 使用logrotate分割Tomcat的catalina日志
  2. Chrome Developer Tools:Network Panel说明
  3. Combobox
  4. 关于HTTP session随笔
  5. iOS改变NavigationBar的返回键和标题颜色、大小
  6. 类似百度音乐唱片播放时CD图片不停旋转的实现
  7. Canvas--2
  8. iOS 发布项目到CocoaPods其实没那么复杂&#128518;
  9. C++(浅析枚举类型-enum)
  10. Mapper 动态代理方式
  11. 给Mac的Dictionary添加其他原装词典
  12. AI五子棋第四周——接近尾声
  13. UEditor学习笔记1
  14. SpringBoot2.0针对请求参数@RequestBody验证统一拦截
  15. mysql修改用户密码的方法及命令
  16. 记一次 mysql 启动没反应
  17. git的搭建与简单实用
  18. oracle 禁用/启动job
  19. Tomcat之配置HTTPS
  20. leetcode462

热门文章

  1. Java多线程(三):volatile
  2. Django框架rest_framework中APIView的as_view()源码解析、认证、权限、频率控制
  3. spring源码深度解析— IOC 之 自定义标签解析
  4. Ruby中的各种比较方式对比
  5. 浅谈Linq查询
  6. JavaScript 基础知识 表达式和运算符
  7. CentOs7.5安装FFmpeg
  8. CodeForces 696A:Lorenzo Von Matterhorn(map的用法)
  9. Vue技术点整理-Vue Router
  10. Yarn原理