1
0
mirror of https://github.com/Didnelpsun/CS408.git synced 2026-06-18 01:19:14 +08:00

更新队列

This commit is contained in:
Didnelpsun
2021-09-18 23:58:01 +08:00
parent e19b4bd5ae
commit dfc81c7e13
13 changed files with 299 additions and 51 deletions

View File

@@ -46,13 +46,13 @@
即需要括号成双相对,且大小一样。
括号匹配时会发现最后出现的左括号最先被匹配LIFO。所以就可以通过栈来模拟这个匹配过程。
括号匹配时会发现最后出现的左括号最先被匹配$LIFO$。所以就可以通过栈来模拟这个匹配过程。
自左至右扫描表达式,若遇左括号,则将左括号入栈,若遇右括号,则将其与栈顶的左括号进行匹配,若配对,则栈顶的左括号出栈,否则出现括号不匹配错误,如果需要匹配但是栈空说明有单独的左或右括号,也匹配失败。
### 表达式求值
一般使用的都是中缀表达式例如4+2×3-10÷5,按照运算法则,我们应当先算2×3然后算10÷5 ,再算加法,最后算减法。
一般使用的都是中缀表达式,例如:$4+2\times3-10\div5$,按照运算法则,我们应当先算$2\times3$然后算$10\div5$ ,再算加法,最后算减法。
表达式分为三个部分:操作数、运算符、界限符。
@@ -68,7 +68,7 @@
2. 选择下一个运算符,按照**左操作数 右操作数 运算符**的方式组合一个个新的操作数。
3. 如果还有运算符没有处理就重复步骤二。
如A+B*(C-D)-E/F就是ABCD-*+EF/-ABCD-\*EF/-+。中缀转后缀的结果可以有不同的结果。
$A+B*(C-D)-E/F$就是$ABCD-*+EF/-$和$ABCD-*EF/-+$。中缀转后缀的结果可以有不同的结果。
即使有不同的转换结果,但是如果我们要通过计算机实现这种转换算法,就必须保证算法的唯一性,所以规定后缀表达式中运算符的顺序就是中缀表达式中运算符生效的顺序,即结果是第一个而不是第二个。
@@ -86,7 +86,7 @@
后缀表达式计算的程序实现:
1. 从左往右扫描下一个元素,直到处理所有元素。
2. 若扫描到操作数则压入栈,并回到1,若扫描到运算符则执行3.
2. 若扫描到操作数则压入栈,并回到$1$,若扫描到运算符则执行$3$。
3. 扫描到运算符则弹出两个栈顶元素,执行相应操作,运算结果压入栈,回到步骤一。
4. 先出栈的是右操作数,后出栈的是左操作数。
@@ -117,9 +117,9 @@
### 递归
函数调用的特点最后被调用的函数最先执行结束LIFO。
函数调用的特点:最后被调用的函数最先执行结束$LIFO$
函数调用时需要一个栈存储:调用返回地址、实参、局部变量。
函数调用时需要一个栈存储:调用返回地址、实参、局部变量。用栈来让递归算法转换为非递归算法。
递归可以将原始问题拆分为属性相同、规模较小的问题。但是如果太多层会造成栈溢出。