前缀、中缀、后缀互相转换

以中缀式子5+10*(2+6)-8 作为例子导向。

中缀->前缀

首先构造一个运算符栈,然后从右至左扫描中缀表达式。如果是操作数,则直接输出;如果是运算符,则比较优先级:若该运算符优先级大于等于栈顶元素,则将该运算符入栈,否则栈顶元素出栈并输出,直到该运算符大于等于栈顶元素的优先级时,再将该运算符压入栈中。遇到右括号直接压入栈中,如果遇到一个左括号,那么就将栈顶元素弹出并输出,直到右括号,但左右括号并不输出。最后,若运算符栈中还有元素,则将栈顶元素逐个弹出并输出,最后将输出表达式翻转。

例:5+10*(2+6)-8

step 1.
Step 2.
Step 3.
Step 4、5、6
Step 7、8
Step 9、10
Step 11、12
Step 13、inverse

中缀 ->后缀

规则和中缀到前缀类似,但是是从左往右扫描,并且结果不需要翻转。

  1. 如果是操作数,则直接输出;
  2. 如果是运算符,则比较优先级:若该运算符优先级大于栈顶元素(或栈为空),则将该运算符入栈,否则栈顶元素出栈并输出,直到该运算符大于栈顶元素(或栈为空)的优先级时,再将该运算符压入栈中。
  3. 遇到左括号直接压入栈中,如果遇到一个右括号,那么就将栈顶元素弹出并输出,直到左括号,但左右括号并不输出。
  4. 最后,若运算符栈中还有元素,则将栈顶元素逐个弹出并输出。

例:5+10*(2+6)-8        --》 5 10 2 6 + * + 8 - 

       2*(9+6/3-5)+4  --》 2 9 6 3 / +5 -  * 4 +

前缀&后缀 ->中缀

前缀和后缀转中缀方法类似。

前缀->中缀:从右往左扫描(数字在右侧),遇到数字压入栈,遇到运算符则依次弹出栈顶两个元素进行运算,运算结果压入栈中,如此循环,直到表达式结束。

例:+ - * ^ A B C D / E / F + G H   --》  A ^ B * C - D + E / (F / ( G + H) )

后缀->中缀:从左往右扫描(数字在左侧),其余规则相同。

例:652 3+8*+3+*   --》 6*((5+(2+3)*8)+3)

 

  • 6
    点赞
  • 24
    收藏
    觉得还不错? 一键收藏
  • 3
    评论
为了回答你的问题,我将介绍前缀中缀后缀表达式,并展示如何在它们之间进行转换。 1. 前缀表达式(也称为波兰式): 在前缀表达式中,运算符位于操作数之前。例如,表达式 "2 + 3" 的前缀形式为 "+ 2 3"。 2. 中缀表达式: 中缀表达式是我们通常使用的常规数学表达式形式。它使用括号和运算符的优先级来表示运算顺序。例如,表达式 "2 + 3" 就是一个中缀表达式。 3. 后缀表达式(也称为逆波兰式): 在后缀表达式中,运算符位于相应的操作数之后。例如,表达式 "2 + 3" 的后缀形式为 "2 3 +"。 现在,我将向你展示如何将中缀表达式转换前缀后缀表达式。 从中缀前缀转换: 1. 反中缀表达式。 2. 将反中缀表达式转换后缀形式。 3. 反后缀表达式即可得到前缀表达式。 从中缀后缀转换: 1. 创建一个空栈和一个空输出列表。 2. 从左到右扫描中缀表达式的每个符号。 - 如果遇到操作数,将其添加到输出列表。 - 如果遇到运算符,将其压入栈中。 - 如果遇到左括号,将其压入栈中。 - 如果遇到右括号,则连续弹出栈顶元素并将其添加到输出列表,直到遇到左括号为止。注意:左括号不会被添加到输出列表中。 如果栈顶元素是左括号,则将其弹出栈。 - 如果遇到的运算符具有比栈顶运算符更高的优先级,将其压入栈中。 如果遇到的运算符具有与栈顶运算符相同的优先级,并且是左结合的运算符,则将栈顶运算符弹出并添加到输出列表中,然后将当前运算符压入栈中。 如果遇到的运算符具有与栈顶运算符相同的优先级,并且是右结合的运算符,则将当前运算符压入栈中。 - 重复步骤2直到扫描完整个中缀表达式。 3. 将栈中剩余的所有运算符弹出并添加到输出列表中。 4. 输出列表即为转换后的后缀表达式。 希望这个解释对你有帮助!如果你有其他问题,可以继续问我。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值