BZOJ4384 : [POI2015]Trzy wieże
首先只有一种字符的情况可以通过双指针在$O(n)$的时间内处理完毕。
设$cnt[i][j]$表示前$i$个字符中$j$字符出现的次数,那么对于两个位置$j<i$:
如果
$cnt[i][0]-cnt[j][0]\neq cnt[i][1]-cnt[j][1]$
$cnt[i][0]-cnt[j][0]\neq cnt[i][2]-cnt[j][2]$
$cnt[i][1]-cnt[j][1]\neq cnt[i][2]-cnt[j][2]$
均成立,即
$cnt[i][0]-cnt[i][1]\neq cnt[j][0]-cnt[j][1]$
$cnt[i][0]-cnt[i][2]\neq cnt[j][0]-cnt[j][2]$
$cnt[i][1]-cnt[i][2]\neq cnt[j][1]-cnt[j][2]$
均成立的话,那么就可以用$i-j$去更新答案。
设$b[i]=cnt[i][0]-cnt[i][1],c[i]=cnt[i][0]-cnt[i][2],d[i]=cnt[i][1]-cnt[i][2]$。
将所有位置按$b$从小到大排序,按$c$维护树状数组,每个区间维护$d$不同的$j$的最小值、次小值、最大值、次大值即可。
时间复杂度$O(n\log n)$。
#include<cstdio>
#define N 1000010
int n,m,i,j,D,cnt[3],col,b[N],c[N],d[N],g[N<<1],nxt[N],v[N<<1],ans;char a[N];
struct P{
int mi0,mi1,ma0,ma1;
P(){mi0=mi1=ma0=ma1=-1;}
void up(){
if(mi0<0){mi0=ma0=j;return;}
if(j<mi0){
if(D!=d[mi0])mi1=mi0;
mi0=j;
}else if((mi1<0||j<mi1)&&D!=d[mi0])mi1=j;
if(j>ma0){
if(D!=d[ma0])ma1=ma0;
ma0=j;
}else if(j>ma1&&D!=d[ma0])ma1=j;
}
}T[N];
inline int id(char x){
if(x=='B')return 0;
if(x=='C')return 1;
return 2;
}
inline void up(int a){if(ans<a)ans=a;}
inline void addedge(int x,int y){nxt[y]=g[x];g[x]=y;}
inline void ins(int x){for(;x<=m;x+=x&-x)T[x].up();}
inline void ask(int x){
for(;x;x-=x&-x){
P*t=T+x;
if(~t->mi0){
if(D!=d[t->mi0])up(j-t->mi0);else if(~t->mi1)up(j-t->mi1);
if(D!=d[t->ma0])up(t->ma0-j);else if(~t->ma1)up(t->ma1-j);
}
}
}
inline void add(int x){if(!cnt[x])col++;cnt[x]++;}
inline void del(int x){cnt[x]--;if(!cnt[x])col--;}
int main(){
scanf("%d%s",&n,a+1);
for(i=1;i<=n;i++){
cnt[a[i]=id(a[i])]++;
b[i]=cnt[0]-cnt[1],c[i]=cnt[0]-cnt[2],d[i]=cnt[1]-cnt[2];
}
for(i=0;i<=n+n;i++)g[i]=-1;
for(i=0;i<=n;i++)addedge(b[i]+n,i),v[c[i]+=n+1]=1;
for(i=1;i<=n+n+1;i++)v[i]+=v[i-1];
for(i=0;i<=n;i++){
c[i]=v[c[i]];
if(c[i]>m)m=c[i];
}
for(i=0;i<=n+n;i++){
for(j=g[i];~j;j=nxt[j])D=d[j],ask(c[j]-1);
for(j=g[i];~j;j=nxt[j])D=d[j],ins(c[j]);
}
for(i=0;i<=n;i++)c[i]=m-c[i]+1;
for(i=1;i<=m;i++)T[i]=P();
for(i=0;i<=n+n;i++){
for(j=g[i];~j;j=nxt[j])D=d[j],ask(c[j]-1);
for(j=g[i];~j;j=nxt[j])D=d[j],ins(c[j]);
}
for(i=0;i<3;i++)cnt[i]=0;
for(i=j=1;i<=n;up(i-j+1),i++)for(add(a[i]);col>1;del(a[j++]));
return printf("%d",ans),0;
}
BZOJ4384 : [POI2015]Trzy wieże的更多相关文章
- 【BZOJ4384】[POI2015]Trzy wieże 树状数组
[BZOJ4384][POI2015]Trzy wieże Description 给定一个长度为n的仅包含'B'.'C'.'S'三种字符的字符串,请找到最长的一段连续子串,使得这一段要么只有一种字符 ...
- BZOJ 4384: [POI2015]Trzy wieże
4384: [POI2015]Trzy wieże Time Limit: 20 Sec Memory Limit: 128 MBSubmit: 217 Solved: 61[Submit][St ...
- [POI2015]Trzy wieże
[POI2015]Trzy wieże 题目大意: 给定一个长度为\(n(n\le10^6)\)的仅包含'B'.'C'.'S'三种字符的字符串,请找到最长的一段连续子串,使得在这一段内出现过的所有字符 ...
- POI2015题解
POI2015题解 吐槽一下为什么POI2015开始就成了破烂波兰文题目名了啊... 咕了一道3748没写打表题没什么意思,还剩\(BZOJ\)上的\(14\)道题. [BZOJ3746][POI20 ...
- [Poi2015]
[POI2015]Łasuchy 一看以为是sb题 简单来说就是每个人获得热量要尽量多 不能找别人 首先这道题好像我自己找不到NIE的情况 很容易想到一个优化 如果一个数/2>另一个数 那么一定 ...
- bzoj AC倒序
Search GO 说明:输入题号直接进入相应题目,如需搜索含数字的题目,请在关键词前加单引号 Problem ID Title Source AC Submit Y 1000 A+B Problem ...
- poi2015 bzoj4377-4386训练
就按时间顺序写吧 完成度:10/10 3.30 bzoj4385 首先一定是删去连续d个数,然后枚举终点,起点显然有单调性,用单调队列乱搞搞就可以啦 bzoj4378 首先才结论:可行当且仅当把所有大 ...
- BZOJ 4385: [POI2015]Wilcze doły
4385: [POI2015]Wilcze doły Time Limit: 10 Sec Memory Limit: 128 MBSubmit: 648 Solved: 263[Submit][ ...
- Bzoj 3747: [POI2015]Kinoman 线段树
3747: [POI2015]Kinoman Time Limit: 60 Sec Memory Limit: 128 MBSubmit: 553 Solved: 222[Submit][Stat ...
随机推荐
- Java bean validation 规范与参考实现
1.Apache Bval 依赖包:validation-api-1.1.0.Final.jar org.apache.bval.bundle-1.1.1.jar bval-core-1.1.1.ja ...
- Swift - 键盘弹出样式
Swift提供了11种键盘类型: 在开发中,我们可以根据不同的需求,选择不同的键盘样式,例如,当我们只需要输入手机号码时,可以选择纯数字类型的键盘(.NumbersAndPunctuation),当我 ...
- Lattice Diamond 学习之编译、检查和设置约束
在新建工程以及完成代码的输入之后.则就要进行编译,并检测错误. 一. Generate Hierarchy(产生层次结构). 1. 点击Generate Hierarchy 图标或者Design -- ...
- python 中内存映射二进制文件
内存映射一个文件并不会导致整个文件被读取到内存中. 也就是说,文件并没有被复制到内存缓存或数组中.相反,操作系统仅仅为文件内容保留了一段虚拟内存. 当你访问文件的不同区域时,这些区域的内容才根据需要被 ...
- php 注册审核
注册界面 <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3 ...
- 微信支付 - V3支付问题
参考资料:http://www.2cto.com/weixin/201506/407690.html 1.微信公众号支付出错: 当前页面的URL未注册: get_brand_wcpay_reque ...
- 【SQL】检索满足条件的最大值的数据集合
是不是看题目觉的看不懂?其实我自己也看不懂,但是又找不到更好的词来形容. 为了更好的表达我的意思,请看下. 如果有一张成绩表(Points), 学生(student) 成绩(point) 科目(sub ...
- Arch Linux 安装、配置、美化和优化
国庆假期玩了下Arch Linux,发现这货跟Ubuntu之流相差甚远,甚难调教,而且安裝过程全命令行,会有各种问题,各种知识... --- 安装引导器--- -------------------- ...
- git中使用.gitignore文件
在进行协作开发代码管理的过程中,常常会遇到某些临时文件.配置文件.或者生成文件等,这些文件由于不同的开发端会不一样,如果使用git add . 将所有文件纳入git库中,那么会出现频繁的改动和push ...
- HTML页面实现返回顶部效果 go to top
1.首先导入jQuery插件. 2.js代码: $(window).scroll(function () { if($(window).scrollTop()>=100) { $(". ...