package tree; 

import java.util.ArrayList; 
import java.util.List; 

import org.apache.commons.collections.CollectionUtils; 


public class TreeBuilder { 

    /** 
     * 将集合建立成树结构 
     * 
     * @param dirs 
     * @return 
     */ 
    @SuppressWarnings("unchecked") 
    private List<Node> buildListToTree(List<Node> dirs) { 
        List<Node> roots = findRoots(dirs); 
        List<Node> notRoots = (List<Node>) CollectionUtils.subtract(dirs, roots); 
        for (Node root : roots) { 
            root.setChildren(findChildren(root, notRoots)); 
        } 
        return roots; 
    } 

    /** 
     * 找出集合中的根元素 
     * 
     * @param allDirs 
     * @return 
     */ 
    public List<Node> findRoots(List<Node> allNodes) { 
        List<Node> results = new ArrayList<Node>(); 
        for (Node node : allNodes) { 
            boolean isRoot = true; 
            for (Node comparedOne : allNodes) { 
                if (node.getParentId() == comparedOne.getId()) { 
                    isRoot = false; 
                    break; 
                } 
            } 
            if (isRoot) { 
                node.setLevel(0); 
                results.add(node); 
                node.setRootId(node.getId()); 
            } 
        } 
        return results; 
    } 

    /** 
     * 递归找子目录 
     * 
     * @param root 
     * @param allDirs 
     * @return 
     */ 
    @SuppressWarnings("unchecked") 
    private List<Node> findChildren(Node root, List<Node> allNodes) { 
        List<Node> children = new ArrayList<Node>(); 

        for (Node comparedOne : allNodes) { 
            if (comparedOne.getParentId() == root.getId()) { 
                comparedOne.setParent(root); 
                comparedOne.setLevel(root.getLevel() + 1); 
                children.add(comparedOne); 
            } 
        } 
        List<Node> notChildren = (List<Node>) CollectionUtils.subtract(allNodes, children); 
        for (Node child : children) { 
            List<Node> tmpChildren = findChildren(child, notChildren); 
            if (tmpChildren == null || tmpChildren.size() < 1) { 
                child.setLeaf(true); 
            } else { 
                child.setLeaf(false); 
            } 
            child.setChildren(tmpChildren); 
        } 
        return children; 
    } 
    
    public static void main(String[] args) { 
        TreeBuilder tb = new TreeBuilder(); 
        List<Node> allNodes = new ArrayList<Node>(); 
        allNodes.add(new Node(1,0,"节点1")); 
        allNodes.add(new Node(2,0,"节点2")); 
        allNodes.add(new Node(3,0,"节点3")); 
        allNodes.add(new Node(4,1,"节点4")); 
        allNodes.add(new Node(5,1,"节点5")); 
        allNodes.add(new Node(6,1,"节点6")); 
        allNodes.add(new Node(7,4,"节点7")); 
        allNodes.add(new Node(8,4,"节点8")); 
        allNodes.add(new Node(9,5,"节点9")); 
        allNodes.add(new Node(10,100,"节点10")); 
        List<Node> roots = tb.buildListToTree(allNodes); 
        for(Node n:roots){ 
            System.out.println(n); 
        } 
        
    } 
} 






package tree; 

import java.util.List; 

public class Node implements java.io.Serializable { 
private static final long serialVersionUID = -2721191232926604726L; 

private int id; 

private int parentId; 

private Node parent; 

private List<Node> children; 

private String name; 

private int level; 

private int sort; 

private int rootId; 

private String type; 

private boolean isLeaf; 

private String description; 


public Node() { 
super(); 
} 

public Node(int id, int parentId, String name) { 
super(); 
this.id = id; 
this.parentId = parentId; 
this.name = name; 
} 


public String getDescription() { 
return description; 
} 

public void setDescription(String description) { 
this.description = description; 
} 

public int getId() { 
return id; 
} 

public void setId(int id) { 
this.id = id; 
} 

public Node getParent() { 
return parent; 
} 

public void setParent(Node parent) { 
this.parent = parent; 
} 

public int getParentId() { 
return parentId; 
} 

public void setParentId(int parentId) { 
this.parentId = parentId; 
} 

public String getName() { 
return name; 
} 

public void setName(String name) { 
this.name = name; 
} 

public int getLevel() { 
return level; 
} 

public void setLevel(int level) { 
this.level = level; 
} 

public String getType() { 
return type; 
} 

public List<Node> getChildren() { 
return children; 
} 

public void setChildren(List<Node> children) { 
this.children = children; 
} 

public void setType(String type) { 
this.type = type; 
} 

public boolean isLeaf() { 
return isLeaf; 
} 

public void setLeaf(boolean isLeaf) { 
this.isLeaf = isLeaf; 
} 

public int getSort() { 
return sort; 
} 

public void setSort(int sort) { 
this.sort = sort; 
} 



public int getRootId() { 
        return rootId; 
    } 

public void setRootId(int rootId) { 
        this.rootId = rootId; 
    } 






    

    @Override 
    public int hashCode() { 
        final int prime = 31; 
        int result = 1; 
        result = prime * result + id; 
        result = prime * result + parentId; 
        return result; 
    } 

    @Override 
    public boolean equals(Object obj) { 
        if (this == obj) 
            return true; 
        if (obj == null) 
            return false; 
        if (getClass() != obj.getClass()) 
            return false; 
        Node other = (Node) obj; 
        if (id != other.id) 
            return false; 
        if (parentId != other.parentId) 
            return false; 
        return true; 
    } 

    @Override 
public String toString() { 
return "Node {id=" + id + ", parentId=" + parentId 
+ ", children=" + children + ", name=" + name + "}"; 
} 
}