Java递归构建树形数据

Java递归构建树形数据

一、前言

  • 开发工具:IntelliJ IDEA
  • JDK:1.8

二、正文

  • 添加依赖
<!-- https://mvnrepository.com/artifact/org.projectlombok/lombok -->
<dependency>
    <groupId>org.projectlombok</groupId>
    <artifactId>lombok</artifactId>
    <version>1.18.22</version>
    <scope>provided</scope>
</dependency>
<!-- https://mvnrepository.com/artifact/com.alibaba/fastjson -->
<dependency>
    <groupId>com.alibaba</groupId>
    <artifactId>fastjson</artifactId>
    <version>1.2.62</version>
</dependency>
  • 数据节点类: DataNode
package com.example;

import lombok.Data;
import java.util.List;

/**
 * 数据节点
 * */
@Data
public class DataNode {
    private String id;
    private String pid; // 父节点ID
    private String name;
    private List<DataNode> children; // 子节点列表

    public DataNode(String id, String pid, String name) {
        this.id = id;
        this.pid = pid;
        this.name = name;
    }
}
  • 树形数据工具类:TreeDataUtil

支持单根节点数据、多根节点数据和自定义单根节点数据

package com.example;

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

/**
 * 树形数据工具
 * */
public class TreeDataUtil {

    // 数据源
    private List<DataNode> dataNodes = new ArrayList();
    // 默认父节点ID
    private String defaultPID = "0";

    public TreeDataUtil(List<DataNode> dataNodes) {
        this.dataNodes=dataNodes;
    }

    public TreeDataUtil(List<DataNode> dataNodes, String defaultPID) {
        this.dataNodes = dataNodes;
        this.defaultPID = defaultPID;
    }

    /**
     * 构建单根节点树形结构
     * */
    public List<DataNode> builSingleRootTree(){
        List<DataNode> treeMenus =new  ArrayList<>();
        DataNode dataNode = getSingleRootNode();
        if(dataNode != null){
            dataNode=buildChilTree(dataNode);
            treeMenus.add(dataNode);
        }
        return treeMenus;
    }

    /**
     * 构建多根节点树形结构
     * */
    public List<DataNode> builMultipleRootTree(){
        List<DataNode> treeMenus =new  ArrayList<>();
        for(DataNode dataNode : getMultipleRootNode()) {
            dataNode=buildChilTree(dataNode);
            treeMenus.add(dataNode);
        }
        return treeMenus;
    }

    /**
     * 自定义单根节点树形结构
     * */
    public List<DataNode> builCustomSingleRootTree(String text){
        List<DataNode> treeMenus =new  ArrayList<>();
        DataNode dataNode = new DataNode(defaultPID, "RT01", text);
        dataNode=buildChilTree(dataNode);
        treeMenus.add(dataNode);
        return treeMenus;
    }

    /**
     * 递归,构建子树形结构
     * @param pNode 父节点
     * */
    private DataNode buildChilTree(DataNode pNode){
        List<DataNode> chilMenus =new  ArrayList<>();
        for(DataNode dataNode : dataNodes) {
            if(dataNode.getPid().equals(pNode.getId())) {
                // 递归查询当前节点是否还有子节点
                chilMenus.add(buildChilTree(dataNode));
            }
        }
        pNode.setChildren(chilMenus);
        return pNode;
    }

    /**
     * 获取多根节点
     * */
    private List<DataNode> getMultipleRootNode() {
        List<DataNode> roots =new  ArrayList<DataNode>();
        for(DataNode dataNode : dataNodes) {
            if(dataNode.getPid().equals(defaultPID)) {
                roots.add(dataNode);
            }
        }
        return roots;
    }

    /**
     * 获取单根节点
     * */
    private DataNode getSingleRootNode() {
        DataNode result = null;
        for(DataNode dataNode : dataNodes) {
            if(dataNode.getId().equals(defaultPID)) {
                result = dataNode;
                break;
            }
        }
        return result;
    }
}
  • 测试类:App
package com.example;

import com.alibaba.fastjson.JSON;
import java.util.ArrayList;
import java.util.List;

public class App
{
    public static void main( String[] args )
    {
        // 测试数据
        List<DataNode> dataNodes= new ArrayList();
        dataNodes.add(new DataNode("0","RT01","商城"));
        dataNodes.add(new DataNode("DN001","0","电器"));
        dataNodes.add(new DataNode("DN002","0","家居"));
        dataNodes.add(new DataNode("DN011","DN001","电视"));
        dataNodes.add(new DataNode("DN012","DN001","空调"));
        dataNodes.add(new DataNode("DN013","DN001","洗衣机"));
        dataNodes.add(new DataNode("DN021","DN002","沙发"));
        dataNodes.add(new DataNode("DN021","DN002","床垫"));
        dataNodes.add(new DataNode("DN0121","DN012","美的"));
        dataNodes.add(new DataNode("DN0122","DN012","格力"));

        // 构建树形数据
        TreeDataUtil treeDataUtil =new TreeDataUtil(dataNodes);
        dataNodes=treeDataUtil.builSingleRootTree(); // 单根节点
        System.out.println(JSON.toJSONString(dataNodes));
        System.out.println("================================");
        dataNodes=treeDataUtil.builMultipleRootTree(); // 多根节点
        System.out.println(JSON.toJSONString(dataNodes));
        System.out.println("================================");
        dataNodes=treeDataUtil.builCustomSingleRootTree("根节点"); // 自定义单根节点
        System.out.println(JSON.toJSONString(dataNodes));
    }
}
  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

趴着喝可乐

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值