【九度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
原创粉丝点击