思路:一个位num0-num1值=某位num0-num1值相等就代表这段区间内01数字相等,然后还要判断当前位置num0==num1这个情况

#include <bits/stdc++.h>
using namespace std;
typedef long long LL; const int N=1e6+10; char s[N];
int sumone[N];
int sumzero[N];
int mp[2*N]; int main()
{
int len,x;
sumone[0]=0;
sumzero[0]=0;
scanf("%s",s+1);
len=strlen(s+1);
int ans=0;
memset(mp,-1,sizeof(mp));
for(int i=1;i<=len;i++)
{
if((s[i]-'0')==0)
{
sumzero[i]=sumzero[i-1]+1;
sumone[i]=sumone[i-1];
x=sumone[i]-sumzero[i]+500000;
if(mp[x]==-1)
mp[x]=i;
else
ans=max(ans,i-mp[x]);
if(sumone[i]==sumzero[i])
ans=max(ans,i);
}
else
{
sumone[i]=sumone[i-1]+1;
sumzero[i]=sumzero[i-1];
x=sumone[i]-sumzero[i]+500000;
if(mp[x]==-1)
mp[x]=i;
else
ans=max(ans,i-mp[x]);
if(sumone[i]==sumzero[i])
ans=max(ans,i);
}
}
printf("%d\n",ans);
return 0;
}

51nod1393的更多相关文章

  1. [51NOD1393]0和1相等串(前缀和,map)

    题目链接:http://www.51nod.com/onlineJudge/questionCode.html#!problemId=1393 题意:中文题面. 把0看成是-1,并且存一遍前缀和.这样 ...

随机推荐

  1. jquery根据(遍历)html()的内容/根据子元素的内容(元素文本)来选择(查询),在子元素前加入元素

    <ul> <li>First</li> <li>second</li> <li>third</li> </ul ...

  2. Delphi快捷键大全

    Delphi快捷键大全 在过程.函数.事件内部, SHIFT+CTRL+向上的方向键 可跳跃到相应的过程.函数.事件的定义.相反,在过程.函数.事件的定义处,SHIFT+CTRL+向下的方向键 可跳跃 ...

  3. 最简单的基于FFMPEG的Helloworld程序

    ===================================================== 最简单的基于FFmpeg的视频播放器系列文章列表: 100行代码实现最简单的基于FFMPEG ...

  4. 将css 中的16进制颜色, 转化为 rgb格式

    对dojo/_base/Color模块的注解. 源地址 https://github.com/robinxiong/dojo/blob/master/_base/Color.js function f ...

  5. 谈谈EJB是怎样公布Web Service的

    定义 我们常常会听到.xx项目中用到了Web Service.那么.什么是Web Service呢? 首先让我们来了解一下Web Service.Web Service技术.就是能使得执行在不同机器上 ...

  6. ubuntun16.04不支持intel的最新网卡,升级到17.10后解决

    新买的神舟战神电脑.装了ubuntu16.04版本.但是安装后无线网卡无法使用无线网卡型号:是intel的一款网卡02:00.0 Network controller [0280]: Intel Co ...

  7. HLS切片机

    参考: 1,linux下搭建生成HLS所需的.ts和.m3u8文件http://www.cnblogs.com/mystory/archive/2013/04/07/3006200.html2,iPh ...

  8. [2017-09-05]Abp系列——Abp后台作业系统介绍与经验分享

    本系列目录:Abp介绍和经验分享-目录 什么是后台作业系统 后台作业系统即BackgroundJob,从需求上讲,是一套基础设施,允许我们定义一个作业,在未来指定的某个时间去执行. 后台作业的一般场景 ...

  9. go 包的问题

    同一个包下的所有方法,都整合到一个里面去了,通过包名可以任意调用包下的方法. 文件夹的名字必须要和文件里面的package的名字一样,否则会报错... 导文件就是文件所在的包 导包import(),是 ...

  10. 旋转屏幕导致Activity重建

    简单来说,Activity是负责与用户交互的最主要机制,任何“设置”(Configuration)的改变都可能对Activity的界面造成影响,这时系统会销毁并重建Activity以便反映新的Conf ...