2

我有像下面的例子一样的树,每片叶子都是对象。

[1]
 |--[2]
 |   |--[3]
 |   |--[4]
 |       |--[5]
 |--[6]

类结构是:

public class Node {
    private Integer id;
    private List<Node> children;
    public Integer getId()
    {
        return id;
    }
    public void setId(Integer id)
    {
        this.id = id;
    }
    public List<Node> getChildren()
    {
        return children;
    }
    public void setChildren(List<Node> children)
    {
        this.children = children;
    }
}

如果选择叶子 3,则面包屑为 1 2 3。如何从这棵树创建面包屑?我知道如何递归地创建树,但我不知道如何为面包屑选择正确的叶子。

4

2 回答 2

5

您需要在子级中使用父级指针。添加子节点时,父节点可以将子节点的父指针设置为自身。

public class Node {
    private Integer id;
    private Node parent;
    private List<Node> children;
    public Integer getId()
    {
        return id;
    }
    public void setId(Integer id)
    {
        this.id = id;
    }
    public List<Node> getChildren()
    {
        return children;
    }
    public void setChildren(List<Node> children)
    {
        this.children = children;
        for (Node child : children) {
            child.parent = this;
        }
    }
    public Node getParent() {
        return parent;
    }
}

然后,您可以轻松地使用它从选定的叶节点构建您的面包屑。

于 2012-06-20T07:23:40.390 回答
1

您可以在创建过程中将父节点作为字段添加到每个节点。这样你就可以从每个对象到根。

于 2012-06-20T07:23:20.097 回答