栈经典操作之中缀表达式的运算(C++)

这篇博客详细介绍了如何使用C++实现中缀表达式到后缀表达式的转换以及后缀表达式的求值。通过两个栈,一个用于运算符,一个用于存储数值,实现了表达式的正确运算。代码中定义了获取运算符优先级的函数,并提供了完整的中缀转后缀以及后缀求值的C++实现。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

栈经典操作之中缀表达式的运算(C++)

表达式介绍

  1. 中缀表达式:有运算优先级的算术表达式。eg:12+4(3+5)=34
  2. 后缀表达式:运算优先级排序完成的运算符在操作数之后的表达式,后缀表达式的计算为遇到运算符取运算符前最近的两个操作数进行相应的运算符计算。eg:13#4#2/+=13+4/2=15

中缀表达式的运算逻辑

  1. 中缀表达式转后缀表达式
    转换过程需要两个栈,输出栈,运算符栈。
    操作:
    1. 读入操作数,直接压入输出栈。
    2. 读入运算符,压入运算运算符号栈:
      ✳ 若后进的运算符优先级高于先进的,直接压入运算符栈,默认’(‘优先级最高。
      ✳ 若后进的运算符优先级不高于(低于或等于)先进的,则将运算符号栈内不低于(高于或等于)的运算符依次弹出并压入输出栈,之后该后进运算符压入运算符栈。
      ✳ 括号的处理,默认’(‘优先级最高,‘)‘优先级最低,读入’(‘直接压入运算符栈,读入‘)’,弹出运算符栈所有符号并压入输出栈,直到读到’)‘停止,’)‘不从运算符栈弹出但是不压入输出栈。
      ✳ 两个操作数之间用’#'分割。
    3. 结束读取后,输出栈为后缀表达式。
  2. 后缀表达式求值
    后缀表达式求值需要一个数栈用于存储数字。
    ✳ 读入操作数直接压入数栈。
    ✳ 读入运算符一次弹出数栈中的两个数,进行相应的运算符计算,计算结果再次压入数栈。
    ✳ 结束后数栈中有且仅有一个数,为结果。

C++代码

#include <bits/stdc++.h>

using namespace std;

typedef double ElemType;

int getPriority (char op) {
   
    // 获得运算符优先级
    if (op == ')') return 0;
    if (op == '+' || op == '-') return 1;
    if (op == '*' || op == '/') return 2;
    if (op == '^') return 3;
    if (op == '(') return 4;
    return -1;
}

string getPostfixExpression(string str) {
   
    // 中缀表达式转后缀表达式
    string result;
    stack<char> opstack;
    for (int i = 0; i < str.size
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值