除非人品好,能碰巧想到思路,否则基本是做不出来dp的,除了那几个经典的dp模型。。
看了几个前几名的代码,还是t神的代码比较清晰。膜tourist
代码的思路和题解思路基本一致。。。。。

#include <bits/stdc++.h>
using namespace std; const int MAXN = 1234567; char s[MAXN];
int f[MAXN];
int nxt[MAXN],prv[MAXN]; int main()
{
int n;
scanf("%d", &n);
scanf("%s", s);
memset(f,0,sizeof(f));
nxt[n] = n;
//记录以当前位置开始,向后数,第一个0的位置
for(int i = n-1; i >= 0; --i)
{
if(s[i] == '0')
nxt[i] = i;
else
nxt[i] = nxt[i+1];
}
//记录以当前位置开始,向前数,第一个0的位置
for(int i = 0; i < n; ++i)
{
if(s[i] == '0')
prv[i] = i;
else
prv[i] = (i==0?-1:prv[i-1]);
}
//两个部分分别更新当前位置和向后更新
for(int i = 0; i <= n; ++i)
{
//更新11111101...这种形式的子串
if(i >= 3 && s[i-1] == '1' && s[i-2] == '0' && s[i-3] == '1')
{
int j = prv[i-3];
f[i] = max(f[i],f[j+1]+(i-j-3));
if(j != i-4)
f[i] = max(f[i],f[j+2]+(i-j-4));
}
if(i == n)
break;
//更新11111101....这种形式的子串
if(i+3 <= n && s[i] == '1' && s[i+1] == '0' && s[i+2] == '1')
{
int j = nxt[i+2];
f[j] = max(f[j],f[i]+(j-i-2));
if(j != i+3)
f[j-1] = max(f[j-1],f[i]+(j-i-3));
}
f[i+1] = max(f[i+1],f[i]);
}
printf("%d\n",f[n]);
return 0;
}

最新文章

  1. 算法: 斐波那契数列C/C++实现
  2. JAVA求集合中的组合
  3. JSON.stringify 在OA差旅中转换为字符串传给后端,(使用from表单的形式)
  4. c# 前端写代码的情况
  5. web api 2 学习笔记 (OData Batch request)
  6. Uncaught TypeError: Object [object Object] has no method &#39;live&#39;
  7. Mysql MHA(GTID)配置(实操)
  8. angular.js使用ui-router注入报错,这里是版本问题导致的
  9. 笔记javascript
  10. 【1】【leetcode-79】 单词搜索
  11. jQuery实现动态分割div—通过拖动分隔栏实现上下、左右动态改变左右、上下两个相邻div的大小
  12. cpu的组成及分工
  13. 【BZOJ3551】【BZOJ3545】 【ONTAK2010】 Peaks (kruskal重构树+主席树)
  14. 【ES】学习3-请求体查询
  15. ArcGIS案例学习笔记4_1_水文分析
  16. SRM466
  17. 利用Warensoft Stock Service编写高频交易软件--DEMO
  18. linux下 signal信号机制的透彻分析与各种实例讲解
  19. java 合并排序算法、冒泡排序算法、选择排序算法、插入排序算法、快速排序算法的描述
  20. Linux网络配置:设置IP地址、网关DNS、主机名

热门文章

  1. canvas旋转图片
  2. python中操作json
  3. 关于Vector CANoe的讨论
  4. 请自行检查是否安装VC9运行库??
  5. UML时序图(Sequence Diagram)学习笔记
  6. Leetcode844.Backspace String Compare比较含退格的字符串
  7. Ajax--Ajax基于原生javascript:创建Ajax对象、链接服务器、发送请求、接受响应结果
  8. idea 项目热部署设置
  9. C++之ARX 读取配置文件内容时,会出现编码问题(utf-8转unicode)
  10. win10下Anaconda3配置环境变量