中缀表达式转后缀表示式,及后缀表达式的运算规则
创始人
2024-06-03 13:54:39
0

后缀表达式又称为逆波兰表达式

一,中缀表达式如何转后缀表达式

假定给出以下中缀表达式

1+3+2*2-1;

要将该表达式转为后缀表达式,我们要按照一定的规则去走,并且用到栈。

先来看规则中缀转后缀的规则:

前提:我们将上述表达式中的数字称为操作数,运算符号称为操作符。

先不考虑有括号的情况:

  • 遇到操作数就输出
  • 遇到操作符
  •         如果栈为空,就入栈。
  •         如果栈不为空,就与栈顶的元素进行比较,如果比栈顶的操作符优先级高得话就入栈。
  •                                                                              如果比栈顶操作符优先级低(或相等)就出栈顶的操作符,然后该操作符入栈。
  • 中缀表达式走完之后,再将栈中的元素取出。

根据上述规则,对表达式转化的过程如下:

我们再来看中缀表达式里有括号的情况:

1+2+(6-2)*2;

 总结:遇到左括号时,左括号入栈,在遇到右括号之前遇到的操作符都依次入栈,遇到右括号的时候,依次再出栈顶元素直到出到左括号,但是括号不作为输出进行输出。

二,后缀表达式的运算法则

我们就以上面第二组的测试为例,得到其后缀表达式的结果为:1 2 + 6 2 - 2 * +

 将后缀表达式看作在一个栈中。

规则:

  1. 遇到操作数继续向后走
  2. 遇到操作符就将该操作符出栈,再取两次栈顶元素依据该操作符进行运算。
  3. 运算的结果再入栈

过程如下图:

逻辑其实还是并不是那么难的,但是要用代码写出来的话,还是有一定难度的,这里不建议使用C语言去写。

下面是两道力扣上的练习题目:

150.逆波兰表达式求值(中等)

224.基本计算器(困难)

相关内容

热门资讯

监控摄像头接入GB28181平... 流程简介将监控摄像头的视频在网站和APP中直播,要解决的几个问题是:1&...
Windows10添加群晖磁盘... 在使用群晖NAS时,我们需要通过本地映射的方式把NAS映射成本地的一块磁盘使用。 通过...
protocol buffer... 目录 目录 什么是protocol buffer 1.protobuf 1.1安装  1.2使用...
educoder数据结构与算法...                                                   ...
MySQL下载和安装(Wind... 前言:刚换了一台电脑,里面所有东西都需要重新配置,习惯了所...
MFC文件操作  MFC提供了一个文件操作的基类CFile,这个类提供了一个没有缓存的二进制格式的磁盘...
有效的括号 一、题目 给定一个只包括 '(',')','{','}'...
【Ctfer训练计划】——(三... 作者名:Demo不是emo  主页面链接:主页传送门 创作初心ÿ...
Fluent中创建监测点 1 概述某些仿真问题,需要创建监测点,用于获取空间定点的数据࿰...
带头循环双向链表来咯!!! 前言:继上文,我们了解了结构最简单的一种链表---单链表那么我们今天就来...