D. Colorful Points

You are given a set of points on a straight line. Each point has a color assigned to it. For point a, its neighbors are the points which don't have any other points between them and a. Each point has at most two neighbors - one from the left and one from the right.

You perform a sequence of operations on this set of points. In one operation, you delete all points which have a neighbor point of a different color than the point itself. Points are deleted simultaneously, i.e. first you decide which points have to be deleted and then delete them. After that you can perform the next operation etc. If an operation would not delete any points, you can't perform it.

How many operations will you need to perform until the next operation does not have any points to delete?

Input
Input contains a single string of lowercase English letters 'a'-'z'. The letters give the points' colors in the order in which they are arranged on the line: the first letter gives the color of the leftmost point, the second gives the color of the second point from the left etc.

The number of the points is between 1 and 106.

Output
Output one line containing an integer - the number of operations which can be performed on the given set of points until there are no more points to delete.

Input

aabb

Output


Input

aabcaa

Output


思路:模拟一下

AC代码:

 #include<bits/stdc++.h>

 using namespace std;
vector< pair<int,int> > v;
int main(){
string str;
cin>>str;
int num=;
int flag=;
for(int i=;i<=str.size();i++){
if(str[i]!=str[i+]&&(i+)<str.size()){
flag=;
}
if(str[i]!=str[i+]){
v.push_back(make_pair(str[i]-'a',num));
num=;
}else{
num++;
}
}
if(flag){
printf("");
return ;
}
/*vector<pair<int,int> > ::iterator it;
for(it=v.begin();it!=v.end();it++){
cout<<(*it).first<<" "<<(*it).second<<endl;
}
*/
int ans=;//aabcaa while(){
vector<pair<int,int> > ::iterator it;
for(it=v.begin();it!=v.end();it++){
if(it==v.begin()||it==(v.end()-)){
(*it).second--;
continue;
}else{
(*it).second-=;
}
}
vector<pair<int,int> > ::iterator xit;
/*for(xit=v.begin();xit!=v.end();xit++){
cout<<(*xit).first<<" "<<(*xit).second<<endl;
}
*/
vector< pair<int,int> > temp;
vector<pair<int,int> > ::iterator itt;
for(itt=v.begin();itt!=(v.end());itt++){
if((*itt).second>){
if(temp.size()==){
temp.push_back(make_pair((*itt).first,(*itt).second));
}else{
vector<pair<int,int> > ::iterator t=temp.end()-;
if((*itt).first==(*t).first){
(*t).second+=(*itt).second;
}else{
temp.push_back(make_pair((*itt).first,(*itt).second));
}
}
}
}
/*vector<pair<int,int> > ::iterator flag=temp.begin(); cout<<temp.size()<<endl;
for(;flag!=temp.end();flag++){
cout<<(*flag).first<<" "<<(*flag).second<<endl;
}
*/
ans++;
if(temp.size()<=){
break;
}else{
v=temp;
} }
cout<<ans<<endl;
return ;
} /* aabbaaa */

最新文章

  1. SQL Queries from Transactional Plugin Pipeline
  2. WPF自定义控件与样式(9)-树控件TreeView与菜单Menu-ContextMenu
  3. C#异常类相关总结
  4. Web 在线文件管理器学习笔记与总结(2)显示文件列表(名称,类型,大小,可读,可写,可执行,创建时间,修改时间,访问时间)
  5. AFN网络状态的时时监控以及网络的判断、
  6. 离线安装PM2
  7. IOS之表视图添加索引
  8. linux内核打印&quot;BUG: scheduling while atomic
  9. Spring中自己主动装配
  10. 在Eclipse中使用Maven构建SpringMVC项目
  11. 【ASP.NET Web API教程】2.3.7 创建首页
  12. JS中判定问题
  13. python小趣味_520绘制一个心形.
  14. epoch、 iteration和batchsize区别
  15. vim编辑
  16. LVS、Nginx 及 HAProxy 工作原理
  17. 节点的启动与关闭 ros::init()解析(c++)
  18. Linux 配置文件管理
  19. sdk接入
  20. URL编码分析与乱码解决方案

热门文章

  1. 最新精仿Chinaz中国站长网整站源码带全部数据带采集功能
  2. dede时间标签
  3. Python 【格式化字符串】
  4. 【背包问题】PACKING
  5. 4-MySQL DBA笔记-开发进阶
  6. C#picturebox控件图片以json格式上传java后台保存
  7. mvc 登陆界面+后台代码
  8. 小程序 wxs时间戳转字符串
  9. CSS设置元素的隐藏和显示
  10. STM32点亮LED