前缀中缀后缀表达式
参考资料:https://blog.csdn.net/qq1627218380/article/details/20471693
https://www.cnblogs.com/zzliu/p/10801113.html
https://blog.csdn.net/A43802/article/details/88749574
中缀表达式:1 + (2 + 3) × 4 - 5前缀表达式:-+ 1 × + 2 3 4 5后缀表达式:12 3 + 4 × + 5 –
计算机一般用前缀或者后缀表达式进行计算。
前缀表达式求值过程:
1. 从右至左扫描表达式
2. 遇到数字时,将数字压入堆栈,遇到运算符时,弹出栈顶的两个数,用运算符对它们做相应的计算(栈顶元素 op 次顶元素),并将结果入栈
3. 重复上述过程直到表达式最左端,最后运算得出的值即为表达式的结果
后缀表达式求值过程:
1. 从左至右扫描表达式
2. 遇到数字时,将数字压入堆栈,遇到运算符时,弹出栈顶的两个数,用运算符对它们做相应的计算(次顶元素op 栈顶元素 ),并将结果入栈
3. 重复上述过程直到表达式最右端,最后运算得出的值即为表达式的结果
中缀表达式如何转化成前缀表达式:
1. 构造栈S1,S2存储符号以及数字
2. 从右往左扫描表达式
3. 遇到数字,压S2
4. 遇到运算符,则比较S1的栈顶元素
4.1 S1为空或者栈顶为’)’,则运算符直接入栈S1
4.2 若运算符比栈顶运算符优先级高或者相等,运算符压入S1
4.3 否则,弹出S1的栈顶运算符并将其压入S2中,再与S1栈顶运算符相比较
5. 遇到括号时:
5.1 遇到‘)’,直接压入S1
5.2 遇到’(‘,依次弹出S1栈顶运算符,并压入S2,直至遇到’)’,同时丢弃这一对括号
6. 重复2-5步骤,直至表达式左边
7. 表达式扫描结束,将S1剩余运算符压入S2
8. 依次将S2的元素出栈,结果即为前缀表达式
中缀表达式如何转化成后缀表达式:
1. 首先构造一个运算符栈S1和一个储存中间结果的栈S2。
2. 从左至右扫描中缀表达式
3. 如果是操作数时,将其压入S2。
4. 如果是运算符,则与S1栈顶元素比较优先级:
4.1 如果S1为空,或栈顶运算符为右括号“(”,则直接将此运算符入栈;
4.2 否则,若该运算符优先级比栈顶运算符的较高或相等,也将运算符压入S1;
4.3 否则,将S1栈顶的运算符弹出并压入到S2中,再与S1中新的栈顶运算符相比较
5. 遇到括号时:
5.1 如果是左括号“(”,则直接压入S1;
5.2 如果是右括号“)”,则依次弹出S1栈顶的运算符,并压入S2,直到遇到右括号为止,此时将这一对括号丢弃;
6. 重复步骤(2)至(5),直到表达式的最右边;
7. 若表达式扫描完,将S1中剩余的运算符依次出栈并压入S2;
8. 从左往右依次读取S2中的元素,即为对应的后缀表达式。
如何判断一个中缀表达式是不是合法:
https://blog.csdn.net/u011815404/article/details/80012213
判断合法性的主要思路:
1. 给一个数组sum[],从左到右扫描中缀表达式,sum[i]=sum[i]+sum[i-1],前面会影响后面
2. 碰到左括号’(‘,sum[i]++
3. 碰到右括号’)’,sum[i]-- (2,3步骤保证了从左括号到右括号之间的sum[i]为1)
4. 判断sum[最后一个]是不是为0,如果为1,则说明括号不匹配。
5. 运算符与操作数匹配,加减乘除优先级大于1,括号以及操作数优先级为0
6. str[i]和str[i-1]进行匹配,其优先级一定等于0
7. 判断其综合优先级是不是为0,其优先级全大于1,则操作数和运算符不匹配。
8. 长度为 1的特殊情况是不是符合要求