本文主要是介绍后缀表达式转中缀表达式,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!
假定有后缀表达式1 2 3 + 4 * +5 – ,请将它转化为前缀表达式。
利用表达式树:
1.从左到右扫面后缀表达式,一次一个符号读入表达式。2.如果符号是操作数,那么就建立一个单节点树并将它推入栈中。如果符号是操作符,那么就从栈中弹出两个树T1和T2(T1先弹出)并形成一颗新的树,该树的根就是操作符,它的左、右儿子分别是T2和T1(先出的为右子树,后出的为左子树)。然后将指向这棵新树的指针压入栈中
前三个符号是操作数,因此创建三颗单节点树并将指向它们的指针压入栈中
“+”被读入,因此指向最后两颗树的指针被弹出,形成一颗新树,并将指向新树的指针压入栈中。
扫描4和*后
扫描+和5后
这篇关于后缀表达式转中缀表达式的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!