CodeForces 612 C. Replace To Make Regular Bracket Sequence(栈)
2016-02-27 20:16
465 查看
Description
给出一个由{}<>组成的字符串s,定义RBS:可以是空串,如果s1和s2是RBS,那么< s1>s2,(s1)s2,[s1]s2,{s1}s2都是RBS,现在可以对这个串进行一些修改,每次可以将左括号或者右括号的种类改变,但是不能改变括号的方向,问最少需要修改几次才能将原串变成一个RBS,如果不存在合理修改方案则输出Impossible
Input
一个字符串s,长度不超过10^6
Output
如果存在修改方案输出最少修改次数,如果不存在修改方案则输出Impssible
Sample Input
[<}){}
Sample Output
2
Solution
遍历s,遇到左括号则进栈,遇到右括号则取栈顶元素出来判断两个括号是否匹配,不匹配修改次数加一,在遍历的过程中记录res=左括号数量-右括号数量,如果在遍历过程中出现res<0的情况或者在遍历完后res!=0则说明左右括号不匹配输出Impossible,否则存在合理修改方案输出修改次数即可
Code
给出一个由{}<>组成的字符串s,定义RBS:可以是空串,如果s1和s2是RBS,那么< s1>s2,(s1)s2,[s1]s2,{s1}s2都是RBS,现在可以对这个串进行一些修改,每次可以将左括号或者右括号的种类改变,但是不能改变括号的方向,问最少需要修改几次才能将原串变成一个RBS,如果不存在合理修改方案则输出Impossible
Input
一个字符串s,长度不超过10^6
Output
如果存在修改方案输出最少修改次数,如果不存在修改方案则输出Impssible
Sample Input
[<}){}
Sample Output
2
Solution
遍历s,遇到左括号则进栈,遇到右括号则取栈顶元素出来判断两个括号是否匹配,不匹配修改次数加一,在遍历的过程中记录res=左括号数量-右括号数量,如果在遍历过程中出现res<0的情况或者在遍历完后res!=0则说明左右括号不匹配输出Impossible,否则存在合理修改方案输出修改次数即可
Code
#include<cstdio> #include<iostream> #include<cstring> using namespace std; #define maxn 1111111 char c[maxn],s[maxn]; int res,ans; int main() { while(~scanf("%s",c)) { res=ans=0; int len=strlen(c); for(int i=0;i<len;i++) { if(c[i]=='{'||c[i]=='['||c[i]=='('||c[i]=='<')s[++res]=c[i]; else { if(c[i]!=s[res]+1&&c[i]!=s[res]+2)ans++; res--; } if(res<0)break; } if(res) printf("Impossible\n"); else printf("%d\n",ans); } return 0; }
相关文章推荐
- 13.UIStepper
- poj 2533 Longest Ordered Subsequence
- BlueTooth: 蓝牙协议栈实现模式分析
- UIDatePicker控件
- 实现更高级的动画效果—requestAnimationFrame
- Implement Stack using Queues
- java.toString() ,(String),String.valueOf的区别
- zstu 1090 Common Subsequence
- Android消息机制 — Handler-Looper-MessageQueue
- IOS开发--UI进阶之iCarousel学习(待翻译)
- uva 1152 4 Values whose Sum is 0 map会超时
- Xcode7,ios9 issue ,warning合集
- 事件处理方法返回值 return true和false地区别
- 8VC Venture Cup 2016 - Elimination Round-A. Robot Sequence(模拟)
- CodeForces 266E More Queries to Array... 线段树
- 使用PictureBox显示分割图像
- mysql编译安装完成后,启动时报错The server quit without updating PID file
- JSP学习笔记三之response对象和request对象
- CodeForces - 280D k-Maximum Subsequence Sum 线段树模拟费用流操作
- DiGui