2

我有一个问题,我在这个函数中找不到错误,它有时可以很好地处理一些输入,但有时没有,例如这个输入“6 2 / 3 – 4 2 * +”可以帮助任何人。

public static double Evaluating_postfix_expressions(String postfix) throws Exception{
    StringTokenizer st = new StringTokenizer(postfix);
    int numOF_tokens = st.countTokens();
    for (int i = 1; i <= numOF_tokens; i++) {
        Object term = st.nextToken();
        try { // if it is an operand there is no problem
            float x =  Float.parseFloat((String)term);
            stack.push(x);
        } catch (Exception e) { // it is an operator
            float v1 = (float) stack.pop();
            float v2 = (float) stack.pop();
            switch ((String) term) {
            case "+":
                stack.push(v2 + v1);
                break;
            case "-":
                stack.push(v2 - v1);
                break;
            case "*":
                stack.push(v2 * v1);
                break;
            case "/":
                stack.push(v2 / v1);
                break;
            }
        }
    }
    return (float) stack.pop();
}
4

1 回答 1

6

请注意,您输入的运算符不正确:

6 2 / 3 – 4 2 * +

请注意与此处手动输入的版本的区别:

6 2 / 3 - 4 2 * +

您使用了破折号而不是连字符 - 或者相反:

$ echo -n – | xxd
0000000: e280 93                                  ...
$ echo -n - | xxd
0000000: 2d                                       -
$ 

这是不报告任何问题的包罗万象的异常问题的一部分。您应该修改您switch的报告无效运算符,这将使捕获这个更容易。(我只是碰巧觉得它看起来很有趣。)

于 2012-05-03T02:07:26.627 回答