Dijkstra 双栈算数表达式求值法
输入输出采用了 算法4 java库
package first_java;
import java.util.Stack;
import edu.princeton.cs.algs4.StdIn;
import edu.princeton.cs.algs4.StdOut;
public class Evaluate {
public static void main(String[] args) {
Stack<Double> vals = new Stack<Double>();
Stack<String> ops = new Stack<String>();
while(!StdIn.isEmpty()) {
String str = StdIn.readString();
if(str.equals("("));
else if(str.equals("+"))
ops.push(str);
else if(str.equals("-"))
ops.push(str);
else if(str.equals("*"))
ops.push(str);
else if(str.equals("/"))
ops.push(str);
else if(str.equals("sqrt"))
ops.push(str);
else if(str.equals(")")) {
double v = vals.pop();
String op = ops.pop();
if(op.equals("+")) {
v = vals.pop() + v;
vals.push(v);
}
else if(op.equals("-")) {
v = vals.pop() - v;
vals.push(v);
}
else if(op.equals("*")) {
v = vals.pop() * v;
vals.push(v);
}
else if(op.equals("/")) {
v = vals.pop() / v;
vals.push(v);
}
else if(op.equals("sqrt")) {
v = Math.sqrt(v);
vals.push(v);
}
}
else vals.push(Double.parseDouble(str));
}
StdOut.println("The final anwser is : " + vals.pop());
}
}
该方法存在的局限性很大
1.运算符与数字之间需用空格隔开
2.括号中最多只能有一次运算
3.括号不能省