前缀,后缀,中缀表达式

目录

中缀转前缀:

1.算法步骤

2.秒杀算法

中缀转后缀:

1.算法步骤

2.秒杀算法

前缀表达式的计算:

1.算法步骤

2.秒杀算法

中缀表达式的计算:

1.算法步骤

2.秒杀算法

后缀表达式的计算:

1.算法步骤

2.秒杀算法


中缀转前缀:

1.算法步骤

  • 初始化两个空栈,一个用于存储运算符,另一个用于存储中间结果。
  • 从右到左扫描中缀表达式中的每一个字符: 
  1. 如果字符是操作数,直接将其压入中间结果栈。 
  2.  如果字符是右括号‘)’,则从运算符栈中弹出运算符并压入中间结果栈,直到遇到左括号‘(’为止(左括号不压入中间结果栈,因为它不是前缀表达式的一部分)。然后丢弃这个左括号。 
  3. 如果字符是运算符,比较其与运算符栈顶元素的优先级。如果当前运算符的优先级高于或等于栈顶运算符,将当前运算符压入运算符栈。否则,从运算符栈中弹出运算符并压入中间结果栈,然后再比较优先级,直到遇到优先级低于当前运算符的栈顶运算符,再将当前运算符压入运算符栈。
  • 扫描完中缀表达式后,如果运算符栈中还有运算符,依次从栈中弹出并压入中间结果栈。
  • 最终,将中间结果栈中的元素依次弹出并连接起来,得到的字符串就是对应的前缀表达式。

2.秒杀算法

对每个运算符两边都加上括号,已经有括号的不用再加了,把每个运算符移到它所在括号的左边,最后把括号去掉。

比如:

a*(b+c)-d

((a*(b+c))-d)

-(*(a+(bc))d)

-*a+bcd

中缀转后缀:

1.算法步骤

  • 初始化一个空栈和一个空的结果字符串(用于存储后缀表达式)。
  • 从左到右扫描中缀表达式中的每一个字符: 
  1. a. 如果字符是操作数,直接将其添加到结果字符串后面。 
  2. b. 如果字符是左括号‘(’,将其压入栈中。 
  3. c. 如果字符是右括号‘)’,则从栈中弹出运算符并添加到结果字符串,直到遇到左括号为止(左括号不添加到结果字符串,因为它不是后缀表达式的一部分)。 
  4. d. 如果字符是运算符,比较其与栈顶运算符的优先级。如果当前运算符的优先级高于栈顶运算符,将当前运算符压入栈中。否则,从栈中弹出运算符并添加到结果字符串,然后继续比较优先级,直到遇到优先级低于或等于当前运算符的栈顶运算符,再将当前运算符压入栈中。
  • 扫描完中缀表达式后,如果栈中还有运算符,依次从栈中弹出并添加到结果字符串。
  • 最终,结果字符串中的表达式就是对应的后缀表达式。

2.秒杀算法

对每个运算符两边都加上括号,已经有括号的不用再加了,把每个运算符移到它所在括号的右边,最后把括号去掉。

比如:

a*(b+c)-d

((a*(b+c))-d)

((a(bc)+)*d)-

abc+*d-

前缀表达式的计算:

1.算法步骤

  • 初始化一个空的操作数栈。
  • 从右到左扫描前缀表达式中的每一个字符: 
  1. a. 如果字符是操作数,将其压入操作数栈。 
  2. b. 如果字符是运算符,根据运算符的类型和所需的操作数个数进行以下操作:
  3. b(1)对于二元运算符(如+、-、*、/等),从操作数栈中弹出两个操作数,然后进行相应的运算。将运算结果压回操作数栈。
  4. b(2)对于一元运算符(如负号-),从操作数栈中弹出一个操作数,进行相应的运算,然后将运算结果压回操作数栈。
  • 继续上述过程,直到扫描完整个前缀表达式。
  • 在扫描结束后,操作数栈中应该只剩下单一的一个元素,这个元素就是前缀表达式的计算结果。

2.秒杀算法

从后往前,后入栈的先算

比如: + * - 5 3 4

中缀表达式的计算:

1.算法步骤

  • 初始化两个栈:一个用于存储操作数,另一个用于存储运算符和左括号。
  • 从左到右扫描中缀表达式中的每一个字符: 
  1. a. 如果字符是操作数,将其压入操作数栈。 
  2. b. 如果字符是左括号‘(’,将其压入运算符和左括号栈。 
  3. c. 如果字符是右括号‘)’,则从运算符和左括号栈中弹出运算符并压入操作数栈,直到遇到左括号为止(左括号不压入操作数栈,并被丢弃)。这相当于计算了括号内的子表达式。 
  4. d. 如果字符是运算符,比较其与运算符和左括号栈顶元素的优先级。如果当前运算符的优先级低于或等于栈顶运算符,将栈顶运算符弹出并压入操作数栈(可能需要再弹出操作数进行运算,取决于运算符类型),然后将当前运算符压入运算符和左括号栈。否则,直接将当前运算符压入运算符和左括号栈。
  • 扫描完中缀表达式后,如果运算符和左括号栈中还有运算符,依次从栈中弹出并压入操作数栈。
  • 在操作数栈中,最后剩下的一个或多个元素就是中缀表达式的计算结果。如果有多个元素,说明表达式有错误,或者需要进一步处理。

2.秒杀算法

初始化两个栈,(中缀转后缀+后缀表达式的求值)两个算法的结合

比如:A+B-C*D/E+F

后缀表达式的计算:

1.算法步骤

  • 初始化一个空的操作数栈。
  • 从左到右扫描后缀表达式中的每一个字符: 
  1. a. 如果字符是操作数(数字或变量),将其压入操作数栈。 
  2. b. 如果字符是运算符,根据运算符的类型和所需的操作数个数进行以下操作:
  3. b(1)对于二元运算符(如+、-、*、/等),从操作数栈中弹出两个操作数,然后进行相应的运算。将运算结果压回操作数栈。
  4. b(2)对于一元运算符(如负号-),从操作数栈中弹出一个操作数,进行相应的运算,然后将运算结果压回操作数栈。
  • 继续上述过程,直到扫描完整个后缀表达式。
  • 在扫描结束后,操作数栈中应该只剩下单一的一个元素,这个元素就是后缀表达式的计算结果。

2.秒杀算法

从前往后,先入栈的先算

比如: 1 5 3 - * 4 +

  • 17
    点赞
  • 21
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

一吨土豆

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值