C++ 实现前缀表达式求值算法
以下是使用 C++ 实现计算前缀表达式值的代码: ```cpp #include <iostream> #include <stack> #include <string> #include <sstream> // 计算前缀表达式的值 int evaluatePrefix(const std::string& expression) { std::stack<int> stack; // 从右向左扫描表达式 for (int i = expression.length() - 1; i >= 0; --i) { if (isdigit(expression[i])) { // 如果是操作数,将其压入栈中 stack.push(expression[i] - '0'); } else if (expression[i] != ' ') { // 如果是运算符 int operand1 = stack.top(); stack.pop(); int operand2 = stack.top(); stack.pop(); switch (expression[i]) { case '+': stack.push(operand1 + operand2); break; case '-': stack.push(operand1 - operand2); break; case '*': stack.push(operand1 * operand2); break; case '/': stack.push(operand1 / operand2); break; } } } return stack.top(); } int main() { std::string expression; std::getline(std::cin, expression); int result = evaluatePrefix(expression); std::cout << result << std::endl; return 0; } ``` ### 代码解释 1. **evaluatePrefix 函数**: - 该函数接受一个字符串表示的前缀表达式作为参数。 - 使用一个栈 `stack` 来存储操作数。 - 从右向左扫描表达式,遇到操作数就将其压入栈中,遇到运算符就从栈中弹出两个操作数进行计算,并将结果压入栈中。 - 最后栈中的唯一元素就是表达式的值。 2. **main 函数**: - 读取用户输入的前缀表达式。 - 调用 `evaluatePrefix` 函数计算表达式的值。 - 输出计算结果。 ######[AI问答 | 504点数解答 | 2026-03-01 20:37:41]
- 递归下降语法分析程序实例:从文法到 C 代码的完整实现(字节豆包 | 1371点数解答 | 2024-12-12 22:46:04)257
- SQL 实现:精准查询 20 岁选课学生学号、姓名、平均与总成绩(去重取最高) (字节豆包 | 116点数解答 | 2024-10-21 00:46:57)207
- Python 实现球类:精准计算半径、表面积与体积,附输入验证与异常处理!(阿里通义 | 261点数解答 | 2024-11-28 21:19:39)333
- 51 单片机:定时器 0 实现 8 个 LED 循环点亮,附代码及优化建议(字节豆包 | 1193点数解答 | 2024-12-27 15:10:29)298
- JavaScript 开发揭秘:表达式 {{data}} 的工作原理及模板字符串应用(阿里通义 | 226点数解答 | 2023-11-09 01:17:26)234
- 揭秘!Angular表达式 {{yourmodel}} 的工作原理与灵活应用(阿里通义 | 187点数解答 | 2023-11-09 01:18:41)205
- Python 实现实数四则运算:输入表达式输出结果,处理除零与格式错误(字节豆包 | 286点数解答 | 2024-11-17 11:21:58)113
- C 语言实现:输入实数四则运算式输出保留两位小数结果(含特殊情况处理) (字节豆包 | 320点数解答 | 2024-11-17 11:22:27)137
- Python切片操作巧解经典算法:二维数组90°旋转(阿里通义 | 205点数解答 | 2023-10-31 11:05:29)328
- 揭秘iOS开发:常用算法大集合,提升应用性能与体验!(阿里通义 | 246点数解答 | 2023-11-08 00:43:08)281
- 深入解析:Vue2.x与Vuex3.x渲染器的Diff算法奥秘(阿里通义 | 222点数解答 | 2023-11-09 01:35:41)356
- 突破 long 范围限制:用 BigInteger 类实现超大数字竖式乘法运算( | 555点数解答 | 2024-03-17 10:56:49)355