欢迎来到尧图网

客户服务 关于我们

您的位置:首页 > 教育 > 培训 > 括弧匹配检验(信息学奥赛一本通-1354)

括弧匹配检验(信息学奥赛一本通-1354)

2025/10/23 3:22:54 来源:https://blog.csdn.net/2402_84298973/article/details/146464725  浏览:    关键词:括弧匹配检验(信息学奥赛一本通-1354)

【题目描述】

假设表达式中允许包含两种括号:圆括号和方括号,其嵌套的顺序随意,如([ ]())或[([ ][ ])]等为正确的匹配,[( ])或([ ]( )或 ( ( ) ) )均为错误的匹配。

现在的问题是,要求检验一个给定表达式中的括弧是否正确匹配?

输入一个只包含圆括号和方括号的字符串,判断字符串中的括号是否匹配,匹配就输出 “OK” ,不匹配就输出“Wrong”。输入一个字符串:[([][])],输出:OK。

【输入】

输入仅一行字符(字符个数小于255)。

【输出】

匹配就输出 “OK” ,不匹配就输出“Wrong”。

【输入样例】

[(])

【输出样例】

Wrong

【题解代码】

#include<bits/stdc++.h>
using namespace std;int main()
{stack<char> stk;char c;while (cin >> c){if (c == '(' || c == '[')stk.push(c);else if (c == ')' || c == ']'){if (stk.empty()){cout << "Wrong";return 0;}else if (c == ')' && stk.top() == '(') stk.pop();else if (c == ']' && stk.top() == '[') stk.pop();else{cout << "Wrong";return 0;}}}if (stk.empty()) cout << "OK";else cout << "Wrong";return 0;
}

版权声明:

本网仅为发布的内容提供存储空间,不对发表、转载的内容提供任何形式的保证。凡本网注明“来源:XXX网络”的作品,均转载自其它媒体,著作权归作者所有,商业转载请联系作者获得授权,非商业转载请注明出处。

我们尊重并感谢每一位作者,均已注明文章来源和作者。如因作品内容、版权或其它问题,请及时与我们联系,联系邮箱:809451989@qq.com,投稿邮箱:809451989@qq.com

热搜词