二叉树地址

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


public class Area {

	
	
	
	private String value;
	private String parentValue;
	private String label;
	private List<Area> children = new ArrayList<Area>();;
	public String getValue() {
		return value;
	}
	public void setValue(String value) {
		this.value = value;
	}
	public String getParentValue() {
		return parentValue;
	}
	public void setParentValue(String parentValue) {
		this.parentValue = parentValue;
	}
	public String getLabel() {
		return label;
	}
	public void setLabel(String label) {
		this.label = label;
	}

	public List<Area> getChildren() {
		return children;
	}
	public void setChildren(List<Area> children) {
		this.children = children;
	}
	@Override
	public String toString() {
		return "Area [value=" + value + ", parentValue=" + parentValue + ", label=" + label + ", children=" + children
				+ "]";
	}
	
	
}
 /**
    * 获取父节点菜单
    * @param treesList 所有树菜单集合
    * @return
    */
   public final static  Area getZtree(List<Area> treesList){
	      long time = new Date().getTime();
	     
		 Map<String ,Area> MapZtree= new HashMap<String ,Area>();
		 Area root=null;
         for (Area mt : treesList) {
    	   MapZtree.put(mt.getValue(), mt);
         }
         for (String key:MapZtree.keySet())
         {
    	   Area nodeData = MapZtree.get(key);
           //主键是空的则为根目录 根据自己情况定义根目录
           if (nodeData.getParentValue().equals("000000")) {
               root = nodeData;
           }
           else
           {
               //根据该目录的父节点组合其子节点集合
        	   Area zTreeDataInfo =MapZtree.get(nodeData.getParentValue());
               zTreeDataInfo.getChildren().add(nodeData);
           }
       }
         long time1 = new Date().getTime();
         System.out.println(time1-time+"花了多少毫秒");
	return root;
   }
	

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值