遍历/转换表达式树

时间:2015-06-25 03:32:51

标签: java c# algorithm tree

我有一个表达式树,我需要遍历并生成一个特定的字符串。 让我们说我有这棵树

     OR
    /  \
  AND   C
 /   \
A     B

我想把它变成:

(A AND B) OR C

我正在考虑使用顺序遍历,但这不完全是我需要的。

2 个答案:

答案 0 :(得分:2)

最简单的解决方案打印多余的括号:

Visit(node):
  Output "("
  If node.has_left():
    Visit(node.left)
  Output node.label
  If node.has_right():
    Visit(node.right)
  Output ")"

要修复冗余括号问题,请为每个运算符分配左右优先级,就像在运算符优先级解析中一样,并将父节点的优先级传递给访问。只有当访问节点的优先级低于从父节点传递的优先级时,访问才输出括号。

答案 1 :(得分:0)

abstract class Expression {
}

class Binary extends Expression {

    final String operator;
    final Expression left, right;

    Binary(String operator, Expression left, Expression right) {
        this.operator = operator;
        this.left = left;
        this.right = right;
    }

    @Override
    public String toString() {
        return String.format("(%s %s %s)", left, operator, right);
    }
}

class Variable extends Expression {

    final String name;

    Variable(String name) {
        this.name = name;
    }

    @Override
    public String toString() {
        return name;
    }
}

@Test
public void testExpression() {
    Expression e = new Binary("OR", new Binary("AND", new Variable("A"), new Variable("B")), new Variable("C"));
    System.out.println(e);
    // -> ((A AND B) OR C)
}