括号匹配问题(核心:就近匹配原则-后进来的左括号先匹配)
步骤:
遍历字符串
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;
}