博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
【bzoj4236】JOIOJI STL-map
阅读量:4686 次
发布时间:2019-06-09

本文共 1291 字,大约阅读时间需要 4 分钟。

题目描述

JOIOJI桑是JOI君的叔叔。“JOIOJI”这个名字是由“J、O、I”三个字母各两个构成的。
最近,JOIOJI桑有了一个孩子。JOIOJI桑想让自己孩子的名字和自己一样由“J、O、I”三个字母构成,并且想让“J、O、I”三个字母的出现次数恰好相同。
JOIOJI桑家有一份祖传的卷轴,上面写着一首长诗,长度为N,由“J、O、I”三个字母组成。JOIOJIさん想用诗中最长的满足要求的连续子串作为孩子的名字。
现在JOIOJI桑将这首长诗交给了你,请你求出诗中最长的、包含同样数目的“J、O、I”三个字母的连续子串。

输入

第一行一个正整数N,代表这首长诗的长度
接下来一行一个长度为N的字符串S,表示这首长诗,保证每个字符都是“J、O、I”三个字母中的一个

输出

输出一行一个正整数,代表最长的包含等数量“J、O、I”三个字母的最长连续子串的长度。如果不存在这样的子串,输出0

样例输入

10

JOIIJOJOOI

样例输出

6


题解

STL-map

设a[i]为1~i中'J'的个数,b[i]为1~i中'O'的个数,c[i]为1~i中'I'的个数。

那么如果[i+1,j]区间可被选择,一定有a[j]-a[i]==b[j]-b[i]==c[j]-c[i],

即a[j]-b[j]==a[i]-b[i],a[j]-c[j]==a[i]-c[i]。

根据这个我们可以把a[i]-b[i]和a[i]-c[i]存起来,再从左向右找,如果找到就用j-i更新答案,没找到则扔到map里。

理论时间复杂度O(nlogn),实际会更快一些。

考场上懵逼了,写了CDQ分治,效率稍微低了一些,反正就当练手了。

#include 
#include
#include
using namespace std;map
, int> v;char str[200010];int main(){ int n , i , ans = 0 , a = 0 , b = 0; scanf("%d%s" , &n , str + 1); v[make_pair(0 , 0)] = 0; for(i = 1 ; i <= n ; i ++ ) { if(str[i] == 'J') a ++ , b ++ ; if(str[i] == 'O') a -- ; if(str[i] == 'I') b -- ; if(v.find(make_pair(a , b)) == v.end()) v[make_pair(a , b)] = i; else ans = max(ans , i - v[make_pair(a , b)]); } printf("%d\n" , ans); return 0;}

转载于:https://www.cnblogs.com/GXZlegend/p/6616996.html

你可能感兴趣的文章
windows live writer 2012 0x80070643
查看>>
C程序的启动和终止
查看>>
asp.net web 定时执行任务
查看>>
tomcat 和MySQL的安装
查看>>
11.5 内部类
查看>>
Cosine Similarity
查看>>
浅谈JAVA集合框架
查看>>
halt和shutdown 的区别
查看>>
git常用操作
查看>>
京东SSO单点登陆实现分析
查看>>
render()方法是render_to_response
查看>>
u-boot启动第一阶段
查看>>
北京大学2019年数学分析考研试题
查看>>
MySQL批量SQL插入性能优化
查看>>
定义列属性:null,default,PK,auto_increment
查看>>
用户画像展示
查看>>
pyqt pyinstaller使用说明
查看>>
C#中StreamReader读取中文出现乱码
查看>>
引用堆中的对象
查看>>
用CSS开启硬件加速来提高网站性能(转)
查看>>