验证后缀表达式而不进行评估

时间:2019-10-21 22:50:49

标签: java postfix-mta

我正在尝试设计一个程序,该程序仅检查给定表达式是否为有效的后缀。我不希望它在任何时候都将表达式作为过程的一部分进行评估。

我检查的每种方法都涉及在堆叠数字之后然后在遇到运算符时评估表达式。对我来说这不是必需的。

我不知道如何进行评估

2 个答案:

答案 0 :(得分:0)

您没有说哪种表达式有效。提供适当的解决方案需要知道将使用哪些函数(基本上它们具有什么相似性,以及它们有多少参数返回堆栈)。

但是,假设简单计算器的“通常”情况,可以通过线性遍历输入令牌来完成。您只需要计算堆栈中的参数数量。如果我们知道函数的稀疏性(参数数量)和返回堆栈的结果数量,就不必评估函数。

final static Map<String, Integer> arity = new HashMap<String, Integer>() {{
    put("*", 2);
    put("/", 2);
    put("+", 2);
    put("-", 2);
    put("neg", 1);
    put("inv", 1);
    // etc...
}};

static boolean isConstant(String token) {
    return Pattern.matches("^[0-9]+$", token);
}

static boolean valid(String postfix) {
    int availableArguments = 0;
    for(final String token: postfix.split(" +")) {
        if(isConstant(token)) {
            availableArguments += 1;
        } else if(arity.containsKey(token)) {
            final int argumentsRequired = arity.get(token);
            if(argumentsRequired > availableArguments) {
                // argument required
                return false;
            } else {
                availableArguments -= argumentsRequired;
                // not all functions must stack only one result
                availableArguments += 1;
            }
        } else {
            // wrong token
            return false;
        }
    }
    // other values than 1 could be valid
    return availableArguments == 1;
}

public static void main(String... args) {
    for(final String expr: asList("3 4 + *", "3 neg 2 + 5 * neg 4 +")) {
        System.out.printf("'%s' is %svalid%n", expr, valid(expr) ? "": "not ");
    }
}

有输出

'3 4 + *' is not valid
'3 neg 2 + 5 * neg 4 +' is valid

答案 1 :(得分:-1)

像这样使用正则表达式

"Somestring with postfix -text".matches("-test$");