中缀表达式转后缀表达式_前缀中缀后缀表达式

前缀中缀后缀表达式

参考资料: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.       重复上述过程直到表达式最右端,最后运算得出的值即为表达式的结果

9e9db42ed984e797a3394467310378dc.png

中缀表达式如何转化成前缀表达式:

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的特殊情况是不是符合要求

a894fab544c469ac9f673d56dc42913d.png

dc10be0e3d837fad9a440cb3f09de5d8.png

27486dc5e5823be0c79364cd71ab3aa4.png

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值