java后端一维数组(List集合)转换成树形结构和树形结构转换为一维数组(List集合)

这篇博客介绍了如何在Java后端将一维数组(List集合)转换成树形结构,以及如何将树形结构转换回一维数组。文章详细阐述了两个过程的步骤,并提供了具体的代码实现,包括使用forEach循环查找根节点、子节点,以及利用BeanUtils和CollectionUtils进行数据处理。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

一、一维数组(List集合)转换成树形结构

1、首先会拿到一个List集合(这个集合是所有的数据)List<T> source,拿个一个父ID,再创建一个空的List<T> object集合用来存放这个树形

2、拿到以上数据后,forEach循环遍历source,

                ①找出根节点

                ②找出该根节点的所有子节点

                ③将这些子节点放入一个List<T> t 中

                ④根节点.setChildren(t)

                ⑤把这个树放入到object中  object.add(t)

3、代码

public List<T> ListToTree (List<T> source, String parentId){

        List<T> object = new ArrayList();

        source.stream().forEach(v ->{

                //找出根节点

                if(parentId.equals(v.getId())){

                        // 找出该根节点的所有子节点,将这些子节点放入一个List<T> t 中

                        List<T> t = ListToTree (source, v.getId());

                        v.setChildren(t);

                       

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值