java实现递归树形结构_java递归算法经典实例

java实现递归树形结构_java递归算法经典实例近期项目有个需求,需要将组织机构数据拼成树型结构返回至前端。我的做法如下:1.由于前端展示使用的组件需要特定的属性key,所以我定义了一个VO对象,代码如下:(本人使用了Lombok插件)packagetop.yuxuange.vo;importlombok.Data;importjava.util.List;@DatapublicclassTreeVO{/***id*/privateStringid;/**

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全系列IDE使用 1年只要46元 售后保障 童叟无欺

近期项目有个需求,需要将组织机构数据拼成树型结构返回至前端。我的做法如下:
1.由于前端展示使用的组件需要特定的属性key,所以我定义了一个VO对象,代码如下:
(本人使用了Lombok插件)

package top.yuxuange.vo;

import lombok.Data;

import java.util.List;

@Data
public class TreeVO {

    /**
     * id
     */
    private String id;

    /**
     * title
     */
    private String title;

    /**
     * 子级
     */
    private List<TreeVO> children;
}

2.编写树型结构工具类:

这是我数据库中组织机构的根节点CODE的截图

1

package top.yuxuange.util;

import org.springframework.stereotype.Component;
import top.yuxuange.model.SysDept;
import top.yuxuange.vo.TreeVO;

import java.util.LinkedList;
import java.util.List;
import java.util.stream.Collectors;

/**
 * 获取组织机构树
 *
 * @author yuxuange
 * @Date 2021-02-03
 */
@Component
public class TreeUtil {

    /**
     * 组织机构表,根节点CODE
     */
    private static final String TREE_ROOT_CODE = "0";
	
	/**
	 * 标准版
	 */
    public static List<TreeVO> getTree(List<SysDept> record) {
        List<TreeVO> treeList = new LinkedList();
        for (SysDept sysDept : record) {
            if (TREE_ROOT_CODE.equals(sysDept.getParentId())) {
                TreeVO treeVO = new TreeVO();
                treeVO.setId(sysDept.getCode());
                treeVO.setTitle(sysDept.getName());
                treeVO.setChildren(getChild(sysDept.getCode(), record));
                treeList.add(treeVO);
            }
        }
        return treeList;
    }

    private static List<TreeVO> getChild(String code, List<SysDept> record) {
        List<TreeVO> childrenList = new LinkedList();
        for (SysDept sysDept : record) {
            if (code.equals(sysDept.getParentId())) {
                TreeVO treeVO = new TreeVO();
                treeVO.setId(sysDept.getCode());
                treeVO.setTitle(sysDept.getName());
                treeVO.setChildren(getChild(sysDept.getCode(), record));
                childrenList.add(treeVO);
            }
        }
        return childrenList;
    }
	
	/**
	 * lamda表达式版
	 */
    public static List<TreeVO> getTreeEX(List<SysDept> record){
        return record.stream().filter(sysDept -> {return TREE_ROOT_CODE.equals(sysDept.getParentId());}).map(sysDept -> {
            TreeVO treeVO = new TreeVO();
            treeVO.setId(sysDept.getCode());
            treeVO.setTitle(sysDept.getName());
            treeVO.setChildren(getChildEX(sysDept.getCode(),record));
            return treeVO;
        }).collect(Collectors.toList());
    }


    private static List<TreeVO> getChildEX(String code,List<SysDept> record){
        return record.stream().filter(sysDept -> {return code.equals(sysDept.getParentId());}).map(sysDept -> {
            TreeVO treeVO = new TreeVO();
            treeVO.setId(sysDept.getCode());
            treeVO.setTitle(sysDept.getName());
            treeVO.setChildren(getChildEX(sysDept.getCode(),record));
            return treeVO;
        }).collect(Collectors.toList());
    }
}

3.查询数据,调用工具类,返回结果如下:
treeResult

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/192299.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • 改变Ubuntu18.04初始键盘布局

    改变Ubuntu18.04初始键盘布局改变 Ubuntu18 04 初始键盘布局安装 Ubuntu 的时候把键盘布局选择成了英文 英国 然后键盘符号就是一团糟 把 打成 很是难受 然后在网上搜索都是依靠代码调出的图形界面来处理 结果重启之后键盘又恢复了原来的样式 可能不适合我的情况吧 自己摸索了以下 发现很简单 用不到那些代码 设置 gt 区域和语言在输入源里选择英语 英国 点击 再点击 选择英语 美

    2025年6月12日
    5
  • 解决mysql操作1045错误,1153错误和1130错误

    解决mysql操作1045错误,1153错误和1130错误

    2021年9月26日
    53
  • 那是什么进程 —— jusched.exe是什么? 它为何运行?「建议收藏」

    那是什么进程 —— jusched.exe是什么? 它为何运行?「建议收藏」       如果你曾经看到任务管理器里有个jusched.exe并很疑惑它究竟是什么,如果你将它关了,那么你很幸运,因为这个进程是负责Java更新的程序,它每个月检查一次Java是否有新的更新,并且一直在那儿浪费内存.       在Windows系统中有个调度任务的功能,由于这个进程每个月才被调度一次,显而易见不是什么重要更新,我不能理解这个进程为什么需要浪费我的内…

    2025年8月8日
    5
  • 3D相机技术 | 立体视觉传感器+TOF相机「建议收藏」

    3D相机技术 | 立体视觉传感器+TOF相机「建议收藏」转自|睿慕课文章结构前言立体视觉传感器原理简介工业领域应用主流立体视觉的产品TOF相机工作原理TOF工业领域应用一些TOF研究机构1.前言在机器视觉应用中,物体三维形状的获取变得越来…

    2022年5月9日
    133
  • Excel 日期和时间函数[通俗易懂]

    Excel 日期和时间函数[通俗易懂]1、TODAY和NOW函数today和now函数日期可以进行加减运算2、提取日期和时间的函数双击右下自动填充完!!!3、WEEKDAY函数weekday函数4、DATEDIF函数

    2022年8月3日
    9
  • mysql er图 属性 联系_数据库er图 联系属性

    mysql er图 属性 联系_数据库er图 联系属性{“moduleinfo”:{“card_count”:[{“count_phone”:1,”count”:1}],”search_count”:[{“count_phone”:4,”count”:4}]},”card”:[{“des”:”阿里云数据库专家保驾护航,为用户的数据库应用系统进行性能和风险评估,参与配合进行数据压测演练,提供数据库优化方面专业建议,在业务高峰期与用户共同保障数据库系统平…

    2022年6月21日
    35

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号