[保研/考研机试] 括号匹配问题 C++实现

题目描述:

在某个字符串(长度不超过100)中有左括号、右括号和大小写字母;规定(与常见的算数式子一样)任何一个左括号都从内到外与在它右边且距离最近的右括号匹配。写一个程序,找到无法匹配的左括号和右括号,输出原来的字符串,并在下一行标出不能匹配的括号。不能匹配的左括号用"$"标注,不能匹配的右括号用"?"标注。

输入描述:

输入包括多组数据,每组数据一行,包含一个字符串,只包含左右括号和大小写字母,字符串

长度不超过100。

输出描述:

对每组输出数据,输出两行,第一行包含原始输入字符,第二行由""、"?"和空格组成,""和"?"表示与之对应的左括号和右括号不能匹配。

源代码:

cpp 复制代码
#include<iostream>
#include<stack>
using namespace std;


//例题5.5 括号匹配问题
int main()
{
	string s;
	cin >> s; // )(rttyy())sss)(
	stack<char> myStack;
	stack<int> myNums;
	for (int i = 0; i < s.size(); i++) {
		if (s[i] == '(') {
			myStack.push(s[i]);
			myNums.push(i);
		}
		if (s[i] == ')') {
			if (!myStack.empty() && myStack.top() == '(') {
				myStack.pop();
				myNums.pop();
			}
			else {
				myStack.push(s[i]);
				myNums.push(i);
			}
		}
	}
	string ss = "a";
	for (int i = 0; i < s.size(); i++) {
		ss += ' ';
	}

	while(!myNums.empty()) {
		if (s[myNums.top()] == '(') {
			ss[myNums.top()] = '$';
			myNums.pop();
		}
		if (s[myNums.top()] == ')') {
			ss[myNums.top()] = '?';
			myNums.pop();
		}
	}

	cout << s << endl;
	cout << ss << endl;

	return 0;
}

运行结果;

相关推荐
_Chipen20 分钟前
C++基础问题
开发语言·c++
灿烂阳光g25 分钟前
OpenGL 2. 着色器
c++·opengl
哦吼!2 小时前
数据结构—二叉树(二)
数据结构
AA陈超2 小时前
虚幻引擎UE5专用服务器游戏开发-20 添加基础能力类与连招能力
c++·游戏·ue5·游戏引擎·虚幻
mit6.8242 小时前
[Meetily后端框架] AI摘要结构化 | `SummaryResponse`模型 | Pydantic库 | vs marshmallow库
c++·人工智能·后端
R-G-B2 小时前
【02】MFC入门到精通——MFC 手动添加创建新的对话框模板
c++·mfc·mfc 手动添加创建新的对话框
linux kernel2 小时前
第七讲:C++中的string类
开发语言·c++
jz_ddk2 小时前
[实战]调频(FM)和调幅(AM)信号生成(完整C语言实现)
c语言·算法·信号处理
Tipriest_3 小时前
[数据结构与算法] 优先队列 | 最小堆 C++
c++·优先队列·数据结构与算法·最小堆
CloudAce云一3 小时前
谷歌云代理商:谷歌云TPU/GPU如何加速您的AI模型训练和推理
算法