List生成树状结构 && 广度优先遍历树节点

实体类
@Data
public class AreaclTreeVO implements Serializable {
    /**
     * 地区编码
     */
    private String code;

    /**
     * 地区名称
     */
    private String name;

    /**
     * 地区类型
     */
    private Integer type;

    /**
     * 子节点
     */
    private List<AreaclTreeVO> children;

    /**
     * 地区主键
     */
    private String pkAreacl;

    /**
     * 父节点主键
     */
    private String pkFatherarea;

}
List生成树结构
    private List<AreaclTreeVO> createAreaTree(){
        Map<String, AreaclTreeVO> map = new HashMap<>();
        // 查询出所有销售地区
        List<AreaclTreeVO> areaclVOList = areaclMapper.selectAreaTree();
        if(CollectionUtils.isEmpty(areaclVOList)){
            return map;
        }
        // 将所有节点存入到map集合
        //将所有主键做为key,AreaclTreeVO对象做值,存入到map集合
         map = areaclVOList.stream()
                .collect(Collectors.toMap(AreaclTreeVO::getPkAreacl, areaclTreeVO -> areaclTreeVO));
        for (AreaclTreeVO areaclTreeVO : areaclVOList) {
            //通过子节点的父节点ID获取父节点
            AreaclTreeVO parent = map.get(areaclTreeVO.getPkFatherarea());
            if(!Objects.isNull(parent)){
                if(Objects.isNull(parent.getChildren())){
                    parent.setChildren(new ArrayList<>());
                }
                //将子节点放入父节点中
                parent.getChildren().add(areaclTreeVO);
            }
        }
          // 查询出第一级销售区域
        List<AreaclTreeVO> result = map.values().stream()
                      .filter(areaclTreeVO -> AreaclTypeEnum.REGION.getCode().equals(areaclTreeVO.getType()))
                .collect(Collectors.toList());
        return result;
    }
广度优先遍历树结构
private List<AreaclTreeVO> breadthFirst(AreaclTreeVO areaclTreeVO) {
        List<AreaclTreeVO> resultList = new ArrayList<>();
        if(Objects.isNull(areaclTreeVO)){
            return resultList;
        }
        Queue<AreaclTreeVO> queue = new LinkedList<>();
        queue.offer(areaclTreeVO);
        while (!queue.isEmpty()) {
            areaclTreeVO = queue.poll();
            //获得节点的子节点
            List<AreaclTreeVO> children = new ArrayList<>();
            if(!Objects.isNull(areaclTreeVO)){
                children = areaclTreeVO.getChildren();
            }
            if (!CollectionUtils.isEmpty(children)) {
                for (AreaclTreeVO child : children) {
                    queue.offer(child);
                }
            }
            resultList.add(areaclTreeVO);
        }
        return resultList;
    }
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值