[保研/考研机试] 括号匹配问题 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;
}

运行结果;

相关推荐
以卿a42 分钟前
C++ 模板初阶
开发语言·c++
计算机小白一个6 小时前
蓝桥杯 Java B 组之设计 LRU 缓存
java·算法·蓝桥杯
万事可爱^6 小时前
HDBSCAN:密度自适应的层次聚类算法解析与实践
算法·机器学习·数据挖掘·聚类·hdbscan
黑不溜秋的6 小时前
C++ 设计模式 - 策略模式
c++·设计模式·策略模式
大数据追光猿8 小时前
Python应用算法之贪心算法理解和实践
大数据·开发语言·人工智能·python·深度学习·算法·贪心算法
Dream it possible!8 小时前
LeetCode 热题 100_在排序数组中查找元素的第一个和最后一个位置(65_34_中等_C++)(二分查找)(一次二分查找+挨个搜索;两次二分查找)
c++·算法·leetcode
夏末秋也凉8 小时前
力扣-回溯-46 全排列
数据结构·算法·leetcode
南宫生8 小时前
力扣每日一题【算法学习day.132】
java·学习·算法·leetcode
柠石榴9 小时前
【练习】【回溯No.1】力扣 77. 组合
c++·算法·leetcode·回溯
Leuanghing9 小时前
【Leetcode】11. 盛最多水的容器
python·算法·leetcode