记'1'为+1,'0'为-1;

可以发现

pre[i],suf[i]分别为前/后缀和

a[i]=max(pre[l.....i]);

b[i]=max(suf[i+1....r]);

ans=max(a[l]+b[l],a[l+1]+b[l+1],........a[r]+b[r]);

即ans=最大的不相交的(前缀和+后缀和)

证明:

首先下界是显然的,即不可能比这个答案更小。

至于上界, 可以大力分类讨论证明。

比如

假如存在一个后缀不合法

设ans=pre[l]+suf[r];

设这个不合法的后缀位置为k。

k>l时:

此时suf[r]显然可以在保证pre[l]不变的情况下找到一个更大的取值,矛盾。

k<l时:

此时有一个显然的结论是

t=sum[l+1..r-1]<=0

因为>0的话显然可以再保证pre[l]不变的情况下找到一个更大的suf[r]。

再设p=sum[k..l-1],p+t显然大于0

显然这时答案不会超过pre[l]-p+suf[r]+p+t=pre[l]+suf[r]+t

因为t<=0,不会更优

得证

最后,用线段树维护即可

每一个节点保存对应区间的区间和,最大前缀,最大后缀,答案

#include<iostream>
#include<cctype>
#include<cstdio>
#include<cstring>
#include<string>
#include<cmath>
#include<cstdlib>
#include<algorithm>
#define N 220000
#define eps 1e-7
#define inf 1e9+7
#define ll long long
using namespace std;
inline int read()
{
char ch=0;
int x=0,flag=1;
while(!isdigit(ch)){ch=getchar();if(ch=='-')flag=-1;}
while(isdigit(ch)){x=(x<<3)+(x<<1)+ch-'0';ch=getchar();}
return x*flag;
}
struct tree
{
int tot,pre,suf,ans;
}node[N*4];
tree operator+(tree a,tree b)
{
tree ans;
ans.tot=a.tot+b.tot;
ans.pre=max(a.pre,b.pre+a.tot);
ans.suf=max(b.suf,a.suf+b.tot);
ans.ans=max(a.pre+b.suf,max(a.ans+b.tot,b.ans+a.tot));
return ans;
}
char s[N];
struct Segment_Tree
{
#define lson o<<1
#define rson o<<1|1
#define mid ((l+r)>>1)
inline void pushup(int o)
{
node[o]=node[lson]+node[rson];
}
void build(int o,int l,int r)
{
if(l==r)
{
if(s[l-1]=='1')node[o]=(tree){1,1,1,1};
else node[o]=(tree){-1,0,0,0};
return;
}
build(lson,l,mid);
build(rson,mid+1,r);
pushup(o);
}
tree query(int o,int l,int r,int ql,int qr)
{
if(ql<=l&&r<=qr)return node[o];
bool flag1=ql<=mid,flag2=qr>mid;
if(flag1&&flag2)
return query(lson,l,mid,ql,qr)+query(rson,mid+1,r,ql,qr);
else
{
if(flag1)return query(lson,l,mid,ql,qr);
if(flag2)return query(rson,mid+1,r,ql,qr);
}
}
}T;
int main()
{
int n=read(),m=read(),i,l,r;
scanf("%s",s);
T.build(1,1,n);
for(i=1;i<=m;i++)
{
l=read();r=read();
printf("%d\n",T.query(1,1,n,l,r).ans);
}
return 0;
}

正睿 2018 提高组十连测 Day4 T3 碳的更多相关文章

  1. 正睿 2018 提高组十连测 Day2 T2 B

    题目链接 http://www.zhengruioi.com/contest/84/problem/318 题解写的比较清楚,直接扒过来了. B 算法 1 直接按题意枚举,动态规划或是记忆化搜索. 时 ...

  2. 正睿OI提高组十连测 day1 总结

    可能是最简单的一场比赛了吧,结果却打得这么差... T1是个找规律题,结果一开始愚蠢地找错了规律,然后又对拍,到1h多一点才过掉 然后看t2和t3,以为t2是个水题,t3也只要处理一下就好了,先写t2 ...

  3. 【正睿oi省选十连测】第一场

    四小时写了两个暴力??自闭 [原来这就是神仙们的分量Orz rank 56/75 可以说是无比垃圾了 下周目标:进步十名?[大雾 T1 题意:有n个点的图 点有点权Ai 也有点权Bi = A_1 + ...

  4. BZOJ NOIP提高组十连测第一场

    今天的题目一共拿了$180$分,感觉自己还是太菜了,二三两题只能骗到部分分 1.$String\ Master$ 题目大意:有两个字符串,在允许k次失配的情况下,求最长公共子串的长度 没什么好讲,直接 ...

  5. [ZJOJ] 5794 2018.08.10【2018提高组】模拟A组&省选 旅行

    Description 悠悠岁月,不知不觉,距那传说中的pppfish晋级泡泡帝已是过 去数十年.数十年 中,这颗泡泡树上,也是再度变得精彩,各种泡泡 天才辈出,惊艳世人,然而,似乎 不论后人如何的出 ...

  6. NOIp 2018 提高组

    T1铺设道路 传送门 题目描述 春春是一名道路工程师,负责铺设一条长度为 $ n $ 的道路. 铺设道路的主要工作是填平下陷的地表.整段道路可以看作是 $ n $ 块首尾相连的区域,一开始,第 ii ...

  7. 2018提高组训练Day2

    A 算法 1 对于每组询问,暴力的算出每个二次函数的取值. 时间复杂度 \(O(nq)\).期望得分 \(20\) 分. 算法 2 当 \(x>0\) 时,要求 \(a_ix^2+b_ix\) ...

  8. NOIP 2018 提高组初赛解题报告

    单项选择题: D 进制转换题,送分: D 计算机常识题,Python是解释运行的: B 常识题,1984年小平爷爷曰:“娃娃抓起”: A 数据结构常识题,带进去两个数据就可以选出来: D 历年真题没有 ...

  9. NOIP 2018 提高组初赛试题 题目+答案+简要解析

    一.单项选择题(共 10  题,每题 2  分,共计 20  分: 每题有且仅有一个正确选项)       1. 下列四个不同进制的数中,与其它三项数值上不相等的是( ). A. (269) 16 B ...

随机推荐

  1. (转载)MySQL基础(非常全)

    MySQL基础 一.MySQL概述 1.什么是数据库 ? 答:数据的仓库,如:在ATM的示例中我们创建了一个 db 目录,称其为数据库 2.什么是 MySQL.Oracle.SQLite.Access ...

  2. 1、My Scripts

    1.写一个包含命令.变量和流程控制的语句来清除/var/log的messages日志文件的shell脚本.(P26)(11-21) 2.利用$0和(dirname.basename)取出当前路径的目录 ...

  3. BZOJ 2002: [Hnoi2010]Bounce 弹飞绵羊(分块)

    http://www.lydsy.com/JudgeOnline/problem.php?id=2002 题意: 思路:不会LCT,就只好用分块了. 将这n个数分成根号n块,对于每一块中的每一个数,处 ...

  4. Scala的配置

    Scala基于Java的JVM,所以先检查是否安装JDK. 在官网上下载并安装好了之后,就是配置环境变量了. SCALA_HOME 变量:C:\Program Files (x86)\scala. P ...

  5. vs项目的属性页面总结

    本文主要针对vs中属性页面的相关选项含义进行了总结.

  6. Java只给汉字转URLEncoder

    public static String encode(String str, String charset) throws UnsupportedEncodingException { Patter ...

  7. 突变注释工具SnpEff,Annovar,VEP,oncotator比较分析--转载

    https://www.jianshu.com/p/6284f57664b9 目前对于variant进行注释的软件主要有4个: Annovar, SnpEff, VEP(variant Effect ...

  8. 【Python】【jupyter-notebook】

    1. win7 安装:https://www.cnblogs.com/zlslch/p/6984403.html 1.Jupyter Notebook 和 pip   为了更加方便地写 Python ...

  9. ngui处理不规则按钮点击

    吐个槽  棋牌类游戏做什么中国地图!!!  然后就要用到不规则按钮点击了 你懂的 213的unity虽然已经加入了polygoncollider 2d的支持 但是 但是 但是 是2d的 也就是说如果不 ...

  10. python requests post和get

    import requests import time import hashlib import os import json from contextlib import closing impo ...