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

括号匹配

题目描述

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

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

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

输入描述

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

输出描述

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

样例

输入

()

输出

Wrong

cpp 复制代码
#include <bits/stdc++.h>

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;
}
相关推荐
To_OC10 小时前
LC 994 腐烂的橘子:人人都说是 BFS 入门题,我却写了三遍才过
javascript·算法·leetcode
金銀銅鐵14 小时前
[Python] 扩展欧几里得算法
python·数学·算法
To_OC16 小时前
LC 200 岛屿数量:经典 DFS 入门题,我第一次写居然连方向都搞错了
javascript·算法·leetcode
To_OC1 天前
LC 128 最长连续序列:别上来就排序,O (n) 解法才是这题的灵魂
javascript·算法·leetcode
05Kevin2 天前
lk每日冒险题--数据结构6.27
算法
To_OC2 天前
从一次栈溢出报错说起,我把递归彻底扒明白了
javascript·算法·程序员
千纸鹤安安3 天前
千问Qwen-AgentWorld来了:一个语言模型搞定七大Agent场景,GPT-5.4都输了
算法
七牛开发者3 天前
MCP 到底是什么?为什么 Agent 都想接上它
算法·aigc·agent