前缀,中缀,后缀表达式转换之趣谈

本文深入探讨了算术表达式从前缀、中缀到后缀的转换方法,通过类比语言学中的主谓宾结构,提出了易于理解的手工转换策略,特别适合于初学者理解和实践。

首先前缀,中缀,后缀表达式的定义不予赘述,教材,网络有详解,从其形式上亦容易看出(所谓前,后,不过符号的位置罢了)。这里主要关注其转换。

  首先举几个简单的例子:

  中缀表达式 a+b           那么它的前缀表达式就应该是 +ab      后缀表达式是 ab+

 

  现在我做几个简单的转换:以中缀表达式a+b为例,a 等于 主语,+ 等于 谓语, b 等于 宾语

  那么  a+b则相当于 主语 谓语 宾语 (亦为世界上语言最常见的语序结构)。

  其前缀表达式+ab则变成了 谓语 主语 宾语 (这种语序代表是圣经希伯来语,当然其他语言中亦存在这种特殊语序。)

  起后缀表达式ab+则变成了 主语 宾语 谓语 (这种像日语,韩语等)

 

  然后从简单的句子推向复杂的句子:

  以中缀表达式转前缀表达式和后缀表达式为例,转换时遵循以下几个原则

  1.从优先级高的运算符开始,连同左右两个数字(要是双目运算符,如果是单目无非缺少主语或者宾语作相应变化,显示不变。)

  2.化完的一个短句(即以上所列的基本句型),将看作一个整体(这种感觉如同从句一样),或看作一个单个数字,继续放回原句,然后转化。(如A*B*C转后缀表达式,A*B化为AB*之后放回成AB**C,此时AB*看作一个字母,再化为AB*C*)

  3.优先级相同的情况下,从左至右化。主要是要保持每个短句中主语和宾语的位置不变。

 

  例:1 + (( 2 + 3)* 4 ) – 5转化为前缀表达式。

  括号中的2+3优先级最高变为+23,总体为1+(+23*4)-5,再化+23*4为*+234,总体为1+*+234-5,再化为+1*+234-5,最后化为-+1*+2345。

 

  同理,从以上不难得出前缀表达式,后缀表达式转中缀的方法。

 

  这种方式相对栈的方法而言更易手工运算,运算符左右两边的顺序不会弄错。总体而言,似乎更像树的方法,只是以“主谓宾”代替“左根右”,个人感觉更加直观,并且在这种文字游戏之中窥见语言学与计算机学中某些有趣的联系。

 

转载请标明出处,原文地址:https://blog.youkuaiyun.com/come_from_pluto/article/details/85171308

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值