前缀、中缀、后缀表达式及树的互相转换及计算

参考:http://www.cnblogs.com/unixfy 

一、中缀表达式转前缀

首先设定一个操作符栈,从右到左顺序扫描整个中缀表达式,如果是操作数,则直接归入前缀表达式;如果是操作符,则检测器是否是右括号,如果是右括号,则直接将其入栈;如果是左括号,则将栈中的操作符依次弹栈,归入前缀表达式,直至遇到右括号,将右括号弹栈,处理结束;如果是其他操作符,则检测栈顶操作符的优先级与当前操作符的优先级关系,如果栈顶操作符优先级大于当前操作符的优先级,则弹栈,并归入前缀表达式,直至栈顶操作符优先级小于等于当前操作符优先级,这时将当前操作符压栈。

         当扫描完毕整个中缀表达式后,检测操作符栈是否为空,如果不为空,则依次将栈中操作符弹栈,归入前缀表达式。最后,将前缀表达式翻转,得到中缀表达式对应的前缀表达式。

二、中缀表达式转后缀 

使用操作符栈;对于操作数直接进入后缀表达式;对于“(”,入栈;对于“)”,弹栈,直至“(”;对于其他操作符,弹栈并进入后缀表达式,直至小于当前操作符优先级或者“(”;扫描中缀表达式后,弹出栈中所有操作符并进入后缀表达式。

总结:

 

中缀转前缀

中缀转后缀

操作符栈

操作符栈

扫描顺序

从右到左

从左到右

遇到操作数

直接归入

直接归入

遇到右括号

直接入栈

将栈中操作符依次弹栈,归入,直至遇到左括号,将左括号弹栈,处理完毕

遇到左括号

将栈中操作符依次弹栈,归入,直至遇到右括号,将右括号弹栈,处理完毕

直接入栈

遇到其他操作符

检测栈顶操作符优先级与当前操作符优先级关系,如果栈顶大于当前,则出栈,归入,直至栈顶小于等于当前,并将当前操作符入栈

检测栈顶与当前优先级关系,如果栈顶大于等于当前则出栈,归入,直至栈顶小于当前,并将当前操作符入栈

操作符栈中的优先级

从栈底到栈顶操作优先级:非递减。即:栈顶可以大于或等于下面的

从栈底到栈顶优先级:递增。即:栈顶必须大于下面的

是否翻转

翻转

无需翻转

三、前缀表达式转中缀表达式

 

你可能感兴趣的:(前缀、中缀、后缀表达式及树的互相转换及计算)