【九度OJ】题目1153:括号匹配问题 解题报告

【九度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 日

posted @ 2017-03-02 15:34  负雪明烛  阅读(47)  评论(0编辑  收藏  举报