创建一个名为parseEqn的方法,该方法将接收1个字符串变量,并返回传递给它的表达式的双精度值。
parseEqn("123+23") → 146.0
parseEqn("3+5") → 8.0
parseEqn("3-5") → -2.0
所以这就是问题^,我认为我需要做的是首先使用字符串标记器将字符串拆分,然后将标记转换为双精度,然后根据operator...but进行加或减,我不确定。
这是我到目前为止所拥有的
public double parseEqn(String str) {
StringTokenizer st = new StringTokenizer(str, "+-", true);
String first= st.nextToken();
String op= st.nextToken();
String second= st.nextToken();
double num1 = Double.parseDouble(first);
double num2 = Double.parseDouble(second);
if (op.equals("+")){
return num1+num2;
}
else (op.equals("-")){
return num1-num2;
}
不过我不知道...
发布于 2014-01-17 01:05:12
编写表达式解析器不是一件微不足道的任务。解析任意中缀表达式的标准算法是shunting-yard algorithm。其思想是遍历每个标记,并根据输入构建一个反向波兰语符号(RPN)表达式。RPN表达式本质上是一个基于堆栈的操作列表,它对计算机来说非常容易使用(并且很容易编写代码进行计算)。
https://stackoverflow.com/questions/21168087
复制相似问题