JAVA将List数据类型转Tree类型

public class TreeVo {
private Integer id;
private Integer fid;
private String name;
List chi;
//省get set方法
}

/**
 * 寻找顶级父节点
 * @param array
 * @return
 */
public static List<TreeVo> getData(List<TreeVo> array) {
       List<TreeVo> list =new ArrayList<>();
       if(array !=null ){
           Set<Integer> set =new HashSet<>();
           Set<Integer> setParentId = new HashSet<>();
           Map<Integer,Object> mapChild = new HashMap<>();

           for (TreeVo treeMode : array) {

               set.add(treeMode.getFid());
               mapChild.put(treeMode.getId(), treeMode);
           }

           for (Integer pid : set) {
               if (mapChild.get(pid) == null) {
                   setParentId.add(pid);
               }
           }
           for(TreeVo treeVo : array){
               if(setParentId.contains(treeVo.getFid())){
                   Integer itemid = treeVo.getId();
                   treeVo.setChi(addList(array, itemid));
                   list.add(treeVo);
               }
           }
       }else {
           return null;
       }

       return list;
}


/**
 * 核心工具类
 * @param array
 * @param itemid
 * @return
 */
private static List<TreeVo> addList(List<TreeVo> array, Integer itemid) {
    List<TreeVo> list = new ArrayList<>();
    for (TreeVo treeModel : array) {
        if (itemid.equals(treeModel.getFid())) {

            Integer cid = treeModel.getId();

            if (addList(array, cid).size() != 0) {
                treeModel.setChi(addList(array, cid));
            }
            list.add(treeModel);
        }
    }

    return list;
}
  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值