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

括号匹配

题目描述

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

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

输入一个只包含圆括号和方括号的字符串,判断字符串中的括号是否匹配,匹配就输出"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;
}
相关推荐
落羽的落羽38 分钟前
【项目】JsonRpc框架——开发实现1(细节功能、字段定义、抽象层、具象层)
linux·服务器·网络·c++·人工智能·算法·机器学习
handler011 小时前
【算法】并查集(普通/扩展/带权)模板与例题
数据结构·c++·笔记·算法·c·图论·查并集
qq7422349841 小时前
从“感知”到“决断”:测评百度伐谋产业决策智能体的端到端推理与行动机制
人工智能·算法·百度·大模型·运筹优化
huohaiyu2 小时前
深入解析Java垃圾回收机制
java·开发语言·算法·gc
浮芷.2 小时前
鸿蒙PC端 TTS 并发调用问题详解:资源竞争与队列管理
算法·华为·开源·harmonyos·鸿蒙·鸿蒙系统
装不满的克莱因瓶2 小时前
掌握感知器的学习原理
人工智能·python·神经网络·算法·ai·卷积神经网络
Lsk_Smion2 小时前
力扣实训 _ [994].腐烂的橘子/图论
算法·leetcode·图论
轻微的风格艾丝凡2 小时前
两电平三相VSC整流模式从不控整流平滑切换至有源整流调试记录
算法·dsp·c2000
dongf20193 小时前
R语言KNN算法
算法·数据分析·r语言
小O的算法实验室3 小时前
2025年IEEE TASE,基于双层耦合平均场博弈的大规模智能体集成任务分配与轨迹规划
人工智能·算法·机器学习