【九度OJ】题目1153:括号匹配问题 解题报告
来源:互联网 发布:新款mac强制关机快捷键 编辑:程序博客网 时间:2024/06/04 18:38
【九度OJ】题目1153:括号匹配问题 解题报告
标签(空格分隔): 九度OJ
http://ac.jobdu.com/problem.php?pid=1153
题目描述:
在某个字符串(长度不超过100)中有左括号、右括号和大小写字母;规定(与常见的算数式子一样)任何一个左括号都从内到外与在它右边且距离最近的右括号匹配。写一个程序,找到无法匹配的左括号和右括号,输出原来字符串,并在下一行标出不能匹配的括号。不能匹配的左括号用”$”标注,不能匹配的右括号用”?”标注.
输入:
输入包括多组数据,每组数据一行,包含一个字符串,只包含左右括号和大小写字母,字符串长度不超过100。
注意:cin.getline(str,100)最多只能输入99个字符!
输出:
对每组输出数据,输出两行,第一行包含原始输入字符,第二行由”
样例输入:
)(rttyy())sss)(
样例输出:
)(rttyy())sss)(? ?$
Ways
堆栈的题目。
栈里边只保存左括号的位置,只要栈不空就代表着存在左括号没有匹配,遇到右括号后,要弹出栈里边的左括号。
同时注意,需要一个output作为保存输出的地方,否则,没法对前面没有匹配的左括号位置进行输出。
另外,需要注意,连续输入的情况下,要保证上一次的结果不会影响之后的结果。所以需要弹出栈中所有的值,而且在output的字符串末尾给出0来保证这次循环已经结束,后面的所有值都不要在输出了。
栈中保存的是位置,这样才能定位是哪里的左括号。
#include <stdio.h>#include <stack>using namespace std;stack<int> S;char input[100];char output[100];int main() { while (scanf("%s", input) != EOF) { int i; for (i = 0; input[i] != 0; i++) { if (input[i] == '(') { S.push(i); output[i] = ' '; } else if (input[i] == ')') { if (S.empty()) { output[i] = '?'; } else { S.pop(); output[i] = ' '; } } else { output[i] = ' '; } } while (!S.empty()) { output[S.top()] = '$'; S.pop(); } output[i] = 0; puts(input); puts(output); } return 0;}
Date
2017 年 3 月 2 日
0 0
- 【九度OJ】题目1153:括号匹配问题 解题报告
- 九度 OJ 题目1153:括号匹配问题
- 九度OJ 题目1153:括号匹配问题
- 题目1153:括号匹配问题 九度OJ
- 九度OJ题目1153:括号匹配问题
- 九度OJ-1153-括号匹配问题
- 九度OJ 1153 括号匹配问题
- 九度 OJ 1153:括号匹配问题
- 【九度】题目1153:括号匹配问题
- 九度题目1153:括号匹配问题
- 九度题目1153:括号匹配问题
- 九度题目1153括号匹配问题
- 【九度】题目1153:括号匹配问题
- 【学习笔记】〖九度OJ〗题目1153:括号匹配问题
- 九度OJ-1153-括号匹配问题
- 九度OJ 1153:括号匹配问题 (DP)
- 括号匹配问题解题报告
- [九度OJ]货币问题,解题报告
- jQuery 常用函数
- 11_python_练习题——日期格式显示
- SHELLEXECUTEINFO 结构详解
- 浅谈Java,面向对象,对象,引用
- 行为型设计模式-解释器模式
- 【九度OJ】题目1153:括号匹配问题 解题报告
- 打印机命令
- 关于语音识别技术的初探
- redis持久化有哪些参数
- vue模板语法
- 2016 Google hosts 持续更新【更新于:2017-01-27】
- 40个Java多线程问题总结(关于多线程最全的总结)
- centos7同步系统时间
- Android keystore的生成|查看