12

我需要一个像这样的树/有向无环图实现:

public class TreeNode<K, V> {
    private K key; // 'key' for this node, always present
    private V value; // 'value' for this node, doesn't have to be set

    private TreeNode<K, V> parent;
    private Set<TreeNode<K, V>> children; 
}
  • 没有任何类型的排序。
  • TreeNode只是键和可能值的包装器(节点不必设置值)。
  • 我需要链接到父母和孩子。

标准 API 或 Commons 等中是否有任何东西可以为我做到这一点?

我不介意自己写(我当然不会要求你们这样做)我只是不想重新发明轮子。

4

4 回答 4

11

好像没有这种东西。上周我问了一个类似的问题,最终实现了我自己的树。我的实现与您提出的非常相似:

public class TreeNode<T>
{
    private LinkedList<TreeNode<T>> children = new LinkedList<TreeNode<T>>();
    public T value { get; set; }

    public TreeNode(T value)
    {
        this.value = value;
    }
    public LinkedList<TreeNode<T>> GetChildren()
    {
        return children;
    }
}

您必须将链接添加回父级。

于 2008-09-27T22:42:17.577 回答
5

还有http://www.jgrapht.org,它拥有 LGPL 许可的软件。不过,我必须警告你,实施你自己的做法充满了危险。如果您打算在结构(即图)上使用递归,则必须确保它是非循环的,否则您将遇到无限循环问题。最好在他们已经处理过问题的地方使用第三方代码。

于 2009-01-13T21:25:43.547 回答
1

我会说最好推出你自己的实现(此外,你已经很好地考虑了接口)。无论如何,您打算在这棵树上执行什么操作?您可能希望围绕您想要的东西设计您的 API……通过键/值直接访问各个节点?遍历类型?添加/删除操作?

于 2008-09-27T23:11:08.257 回答
0

如果您正在寻找额外的图形功能,JDigraphDigraph类应该符合要求。

于 2008-09-27T23:44:34.400 回答