stack处理括号匹配问题----1353:表达式括号匹配(stack)

括号匹配问题(核心:就近匹配原则-后进来的左括号先匹配)

步骤:

遍历字符串 ​

        1.遇到左括号就入栈 ​

        2.遇到右括号就匹配 ​

判断栈是否为空 ​

        (1)如果栈空了,证明右括号多了,不匹配,结束程序 ​

        (2)如果栈不空,则匹配(出栈) ​

循环结束后,判断栈是否为空 ​

        (1)如果栈空,则完全匹配 ​

        (2)如果栈不空,证明左括号多了,则匹配失败

例题

1353:表达式括号匹配(stack)


时间限制: 1000 ms         内存限制: 65536 KB
提交数: 41456     通过数: 21656

【题目描述】

假设一个表达式有英文字母(小写)、运算符(+,—,∗,/+,—,∗,/)和左右小(圆)括号构成,以“@@”作为表达式的结束符。请编写一个程序检查表达式中的左右圆括号是否匹配,若匹配,则返回“YES”;否则返回“NO”。表达式长度小于255255,左圆括号少于2020个。

【输入】

一行数据,即表达式。

【输出】

一行,即“YES” 或“NO”。

【输入样例】

2*(x+y)/(1-x)@

【输出样例】

YES

【提示】

【样例输入2】

(25+x)*(a*(a+b+b)@

【样例输出2】

NO

  参考代码:C++

#include<iostream>
#include<stack>
#include<string>
using namespace std;
int main() {
	string s; cin >> s;
	stack<int> stk;
	for (int i = 0; i < s.size(); i++) {
		if (s[i] == '(') stk.push(i);//左括号就入栈
		else if (s[i] == ')') {//右括号就匹配
			if (stk.empty()) {
				cout << "NO";
				return 0;
			}
			else stk.pop();//匹配
		}
	}
	if (!stk.empty()) cout << "NO" << endl;
	else cout << "YES";
	return 0;
}

栈处理中缀表达式

栈处理中缀表达式原则(后进先算* /) 步骤: 循环处理 遇到+-后面的数字就入栈,第一个元素前默认+ 遇到*/后面的数字就和栈顶元素进行运算 循环结束后,把栈中元素全部相加

  参考代码:C++

#include<iostream>
#include<stack>
using namespace std;
//栈处理中缀表达式
int main() {
	stack<int> sum;
	char opt; int x; cin >> x;
	sum.push(x);
	//模运算的性质
	while (cin >> opt >> x) {
		if (opt == '+') sum.push(x % 10000);
		else if (opt == '*') {
			sum.top() = sum.top() % 10000 * x % 10000;
			sum.top() %= 10000;
		}
	}
	int ans = 0;
	while (!sum.empty()) {
		ans += sum.top() % 10000;
		ans %= 10000;
		sum.pop();
	}
	cout << ans % 10000 << endl;
	return 0;
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值