0

发布的代码适用于操作,但如果运算符和操作数之间没有间距,则不会工作。

我得到了 4 个表达式来计算

  1. 10 2 8 * + 3 -

  2. 3 14+2*7/

  3. 4 2 + 3 15 1 - * +

  4. 1 2 + 3 % 6 - 2 3 + /

(间距很重要)

表达式二是不会使用我当前的计算器计算的

这是我的代码

  import java.util.*;
  public class PostFix {

   public static void main(String []args){

    Stack<Integer> stack = new Stack<Integer>();
    System.out.println("Input your expression using postfix notation");
    Scanner input = new Scanner(System.in);
        String expr = input.nextLine();
        StringTokenizer tokenizer = new StringTokenizer(expr);

    while(tokenizer.hasMoreTokens()){
        String c = tokenizer.nextToken();
        if(c.startsWith("0")|| c.startsWith("1")||c.startsWith("2")||c.startsWith("3")||c.startsWith("4")||
            c.startsWith("5")||c.startsWith("6")||c.startsWith("7")||c.startsWith("8")||c.startsWith("9"))
            stack.push(Integer.parseInt(c));
        else if(c.equals("+")){
            int op1 = stack.pop();
            int op2= stack.pop();
            stack.push(op2+op1);
        }
        else if(c.equals("-")){
            int op1 = stack.pop();
            int op2= stack.pop();
            stack.push(op2-op1);
        }
        else if(c.equals("*")){
            int op1 = stack.pop();
            int op2= stack.pop();
            stack.push(op2*op1);
        }
        else if(c.equals("/")){
            int op1 = stack.pop();
            int op2= stack.pop();
            stack.push(op2/op1);
        }
        else if(c.equals("%")){
            int op1 = stack.pop();
            int op2= stack.pop();
            stack.push(op1%op2);
        }



    }
System.out.println(stack.pop());

}
   }

这是堆栈跟踪

 Input your expression using postfix notation
 3 14+2*7/
 Exception in thread "main" java.lang.NumberFormatException: For input string:  "14+2*7/"
at java.lang.NumberFormatException.forInputString(Unknown Source)
at java.lang.Integer.parseInt(Unknown Source)
at java.lang.Integer.parseInt(Unknown Source)
at PostFix.main(PostFix.java:18)
4

3 回答 3

0

使用 StreamTokenizer 进行解析,请参阅http://docs.oracle.com/javase/7/docs/api/java/io/StreamTokenizer.html

StreamTokenizer tokenizer = new StreamTokenizer(new StringReader(expr));
tokenizer.ordinaryChar('/');  // see comments

while(tokenizer.nextToken() != StreamTokenizer.TT_EOF){
  if (tonenizer.ttype == StreamTokenizer.TT_NUMBER) {
    stack.push(Integer.parseInt(tokenizer.sval));
  } else {
    int op1 = stack.pop();
    int op2 = stack.pop();
    switch (ttype) {
      case '+': op2 += op1; break;
      case '-': op2 -= op1; break;
      case '*': op2 *= op1; break;
      case '/': op2 /= op1; break;
    }
    stack.push(op2);
  }
}
于 2013-11-16T01:25:54.797 回答
0

或者,如果您不能使用 StreamTokenizer,请使用 StringTokenizer 构造函数的 3 参数版本:

StringTokenizer tokenizer = new StringTokenizer(expr, " +*-/", true);

这将制作 ' '、'+'、'*'、'-' 和 '/' 定界符,并将它们报告为标记。

于 2013-11-16T01:59:34.113 回答
0

如果您真的必须使用StringTokenizer,请像这样构造它:

StringTokenizer tokenizer = new StringTokenizer(expr, " +-*/%", true);

第二个参数表示除了空格之外,空格和所有运算符都被视为分隔符。第三个参数表示分隔符被视为标记,因此当它看到"+","-"等时,它将作为字符串返回。它还会返回空格,因此您必须确保在nextToken返回" "时忽略它并且不要将其视为错误。

于 2013-11-16T02:01:39.277 回答