c++栈实现简易计算器
时间: 2023-11-20 16:50:18 浏览: 168
用C++线性栈实现简易计算器
5星 · 资源好评率100%
好的,以下是C++栈实现简易计算器的代码:
```c++
#include <iostream>
#include <stack>
#include <string>
using namespace std;
int main() {
stack<int> numStack; // 存储数字的栈
stack<char> opStack; // 存储运算符的栈
string expression; // 表达式字符串
cin >> expression;
int len = expression.length();
for (int i = 0; i < len; i++) {
char ch = expression[i];
if (ch >= '0' && ch <= '9') { // 如果是数字,入数字栈
numStack.push(ch - '0');
} else { // 如果是运算符
if (opStack.empty() || ch == '(') { // 如果运算符栈为空或者当前运算符是左括号,直接入栈
opStack.push(ch); } else if (ch == ')') { // 如果当前运算符是右括号,弹出运算符栈中的元素直到遇到左括号
while (opStack.top() != '(') {
int num2 = numStack.top();
numStack.pop();
int num1 = numStack.top();
numStack.pop();
char op = opStack.top();
opStack.pop();
int result;
if (op == '+') {
result = num1 + num2;
} else if (op == '-') {
result = num1 - num2;
} else if (op == '*') {
result = num1 * num2;
} else {
result = num1 / num2;
}
numStack.push(result);
}
opStack.pop(); // 弹出左括号
} else { // 如果当前运算符是加减乘除
while (!opStack.empty() && opStack.top() != '(' && ((ch == '*' || ch == '/') || (opStack.top() == '+' || opStack.top() == '-'))) {
int num2 = numStack.top();
numStack.pop();
int num1 = numStack.top();
numStack.pop();
char op = opStack.top();
opStack.pop();
int result;
if (op == '+') {
result = num1 + num2;
} else if (op == '-') {
result = num1 - num2;
} else if (op == '*') {
result = num1 * num2;
} else {
result = num1 / num2;
}
numStack.push(result);
}
opStack.push(ch);
}
}
}
while (!opStack.empty()) { // 处理剩余的运算符
int num2 = numStack.top();
numStack.pop();
int num1 = numStack.top();
numStack.pop();
char op = opStack.top();
opStack.pop();
int result;
if (op == '+') {
result = num1 + num2;
} else if (op == '-') {
result = num1 - num2;
} else if (op == '*') {
result = num1 * num2;
} else {
result = num1 / num2;
}
numStack.push(result);
}
cout << numStack.top() << endl; // 输出最终结果
return 0;
}
```
这个程序可以处理包含加减乘除和括号的表达式,但是没有考虑负数的情况。
阅读全文