1. 后缀表达式
后缀表达式,即为逆波兰表达式,其运算方法为从左到右扫描表达式,当遇到符号时,取该符号前两位数,使用前一个数运算后一个数,将结果放入刚才两个数的位置,运算的两个数以及符号便去掉。由此得知,使用栈运算会很方便,下面会有完整的计算一个四则运算表达式的代码
2. 思路分析
1.将字符串转化为list,目的是方便操作
2.简历一个符号栈与结果队列,符号栈用于存储遍历得到的符号,队列利用其先进先出的特性来记录转化后的后缀表达式
3.遍历该list
3.1该元素为数字,直接入结果队列
3.2该元素为符号
3.2.1栈为空或者栈顶元素为”(“,则将该元素直接入符号栈
3.2.2栈顶元素优先级小于该元素,则将该元素直接入符号栈
3.2.3如果不满足以上条件,则将栈顶元素入结果队列,并且从3.2.1继续开始进行判断
3.3遍历list结束后,将栈中剩余的元素依次加入结果队列中,结果即为对应的后缀表达式
3. 代码实现
//本代码包含: 中缀表达式转化后缀表达式,计算后缀表达式
package stack;
import java.util.ArrayList;
import java.util.LinkedList;
import java.util.List;
import java.util.Stack;
/**
* 逆波兰计算器
*/
public class ReversePolish {
public static void main(String[] args) {
String s = "2*(16+8/4-5)+4";
ReversePolish reversePolish = new ReversePolish();
System.out.println(reversePolish.toReversePolish(stringToList(s)).toString());
System.out.println(reversePolish.calculate(reversePolish.toReversePolish(stringToList(s))));
}
private List<String> toReversePolish(List<String> list){
Stack<String> stack = new Stack<String>();
List<String> linkedList = new LinkedList<String>();
for (int i = 0; i < list.size(); i++){
String s = list.get(i);
int chk = check(s);
//如果当前元素为符号<