树形列表结构

 

命题要求:将如下表中前两个数字字符相同的,并且后两个不为00的归为在00的子节点,形成树形结构

 

 

核心源码:

1
2
3
4
5
6
7
8
9
10
11
12
13
private List<TypeTree> listToTree(List<Integer> typeNumList,List<TypePolicy> list , int pid ){
        List<TypeTree> typeTrees = new ArrayList<>();
        for(int i = 0 ; i<list.size() ; i++) {
            if (list.get(i).getPid() == pid) {
                TypeTree typeTree = new TypeTree();
                typeTree.setId(list.get(i).getId());
                typeTree.setLabel(list.get(i).getType()+"("+typeNumList.get(i)+")");
                typeTree.setChildren(listToTree(typeNumList,list,list.get(i).getId()));
                typeTrees.add(typeTree);
            }
        }
        return typeTrees;
    }

  

这里我用到了递归的思想

最终效果

 

posted @   枫浔  阅读(107)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· 阿里最新开源QwQ-32B,效果媲美deepseek-r1满血版,部署成本又又又降低了!
· AI编程工具终极对决:字节Trae VS Cursor,谁才是开发者新宠?
· 开源Multi-agent AI智能体框架aevatar.ai,欢迎大家贡献代码
· Manus重磅发布:全球首款通用AI代理技术深度解析与实战指南
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!
历史上的今天:
2021-10-27 C语言数据结构学习pta的问题
点击右上角即可分享
微信分享提示