杨校老师课堂之栈结构的专项训练

括号匹配

题目描述

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

本题的任务是检验一个给定的表达式中的括号是否匹配正确

输入一个只包含圆括号和方括号的字符串,判断字符串中的括号是否匹配,匹配就输出"OK",不匹配就输出"Wrong"

输入描述

一行字符,只含有圆括号和方括号,个数小于255

输出描述

匹配就输出一行文本"OK",不匹配就输出一行文本"Wrong"

样例

输入

(\]) 输出 Wrong ```cpp #include using namespace std; char st[260]; // 栈顶指针: top int top = 0; // 1. 栈顶指针往上跳一个,top = 1; // 2. 加一个数据到栈里面 添加数据 int main(){ string s; cin >> s; // [()] // 字符串长度:len是4 int len = s.size(); // len = 4 // cout << s[0];// // 循环 0~3,len-1就是3 for(int i=0;i< len;i++){ if(s[i] == '[' || s[i] == '(' ){ // 进栈 // ++top 加号加号在前、先++,原来top = 0, 加后为1 st[++top] = s[i]; } // 配对 [ ] if(s[i] == ']'){ // 此时栈顶数据是 [ if(st[top] == '['){ // 成功了,出栈 --top; }else{ // 失败了 cout << "Wrong"; // 提前结束程序 return 0; } } // 配对 ( ) if(s[i] == ')'){ // 此时栈顶数据是 ( if(st[top] == '('){ // 成功了,出栈 --top; }else{ // 失败了 cout << "Wrong\n"; // 提前结束程序 return 0; } } } // 判断成功 // 栈顶指针指向0 表示空栈 全部配对成功; if(top == 0){ cout << "OK"; } else{ // 栈内没有空 cout << "Wrong\n"; } return 0; } ```

相关推荐
故事和你912 小时前
洛谷-算法2-2-常见优化技巧3
开发语言·数据结构·c++·算法·深度优先·动态规划·图论
菜鸟555552 小时前
2025江西省CCPC省赛暨全国邀请赛(南昌)
数据结构·c++·算法·acm·思维·ccpc·xcpc
lds走自己的路2 小时前
全局坐标转局部坐标推导
人工智能·算法·机器学习
杨校2 小时前
杨校老师课堂之C++高精度乘法
算法
上弦月-编程2 小时前
C语言位运算:从入门到精通
运维·c语言·开发语言·vscode·算法·leetcode·极限编程
꧁细听勿语情꧂3 小时前
用队列实现栈、用栈实现队列,树、二叉树、满二叉树、完全二叉树,堆、向下向上调整算法、出堆入堆、堆排序
c语言·开发语言·数据结构·算法
碧海银沙音频科技研究院3 小时前
BES2800BP_nuttx编译环境搭建方法
人工智能·深度学习·算法
Felven3 小时前
B. Make Almost Equal With Mod
数据结构·算法
脆皮炸鸡7553 小时前
Linux~~基础IO
linux·运维·服务器·经验分享·算法·学习方法