设为首页收藏本站
网站公告 | 这是第一条公告
     

 找回密码
 立即注册
缓存时间00 现在时间00 缓存数据 对自己狠一点,逼自己努力,再过几年你将会感谢今天发狠的自己、恨透今天懒惰自卑的自己。晚安!

对自己狠一点,逼自己努力,再过几年你将会感谢今天发狠的自己、恨透今天懒惰自卑的自己。晚安!

查看: 1867|回复: 3

Java实现公用实体类转Tree结构

[复制链接]

  离线 

TA的专栏

  • 打卡等级:即来则安
  • 打卡总天数:16
  • 打卡月天数:0
  • 打卡总奖励:221
  • 最近打卡:2024-07-11 01:01:50
等级头衔

等級:晓枫资讯-列兵

在线时间
0 小时

积分成就
威望
0
贡献
36
主题
28
精华
0
金钱
329
积分
76
注册时间
2023-8-13
最后登录
2025-9-24

发表于 2024-10-29 01:08:20 | 显示全部楼层 |阅读模式

工具类

  1. import java.util.*;
  2. import java.util.function.Function;
  3. import java.util.stream.Collectors;
  4. // 树节点类,用于存储树中的每个元素
  5. class TreeNode<T> {
  6. private T data; // 节点存储的数据
  7. private List<TreeNode<T>> children = new ArrayList<>(); // 子节点列表
  8. // 构造函数,初始化节点数据
  9. public TreeNode(T data) {
  10. this.data = data;
  11. }
  12. // 添加子节点
  13. public void addChild(TreeNode<T> child) {
  14. children.add(child);
  15. }
  16. // 获取当前节点的数据
  17. public T getData() {
  18. return data;
  19. }
  20. // 获取当前节点的所有子节点
  21. public List<TreeNode<T>> getChildren() {
  22. return children;
  23. }
  24. }
  25. // 树构建器类,负责从列表构建树形结构
  26. class TreeBuilder<T> {
  27. // buildTree方法,构建树形结构
  28. public TreeNode<T> buildTree(List<T> items, Function<T, String> idExtractor, Function<T, String> parentIdExtractor) {
  29. // 创建一个映射,将每个节点的ID映射到对应的TreeNode对象
  30. Map<String, TreeNode<T>> nodeMap = items.stream()
  31. .map(item -> new TreeNode<>(item)) // 将每个元素转换为TreeNode
  32. .collect(Collectors.toMap(node -> idExtractor.apply(node.getData()), Function.identity()));
  33. TreeNode<T> root = null; // 用于存储根节点
  34. // 遍历每个元素,建立父子关系
  35. for (T item : items) {
  36. String id = idExtractor.apply(item); // 获取当前节点的ID
  37. String parentId = parentIdExtractor.apply(item); // 获取父节点的ID
  38. TreeNode<T> node = nodeMap.get(id); // 获取当前节点
  39. if (parentId == null) {
  40. root = node; // 假设只有一个根节点
  41. } else {
  42. TreeNode<T> parentNode = nodeMap.get(parentId); // 获取父节点
  43. if (parentNode != null) {
  44. parentNode.addChild(node); // 将当前节点添加到父节点的子节点列表中
  45. }
  46. }
  47. }
  48. return root; // 返回构建的树的根节点
  49. }
  50. }
复制代码

注释说明:

TreeNode类:

  • 每个字段和方法都有注释,说明其用途。
  • 包含构造函数、添加子节点的方法以及获取数据和子节点的方法。

TreeBuilder类:

  • buildTree方法的逻辑注释清晰,解释了每一步的目的。
  • 使用映射将每个实体转换为树节点,并建立父子关系。

代码示例

  1. import java.util.Arrays;
  2. import java.util.List;
  3. // 实体类,用于表示树节点的数据
  4. class Entity {
  5. private String id; // 节点ID
  6. private String parentId; // 父节点ID
  7. private String name; // 节点名称
  8. // 构造函数
  9. public Entity(String id, String parentId, String name) {
  10. this.id = id;
  11. this.parentId = parentId;
  12. this.name = name;
  13. }
  14. // 获取节点ID
  15. public String getId() {
  16. return id;
  17. }
  18. // 获取父节点ID
  19. public String getParentId() {
  20. return parentId;
  21. }
  22. // 获取节点名称
  23. public String getName() {
  24. return name;
  25. }
  26. }
  27. // 主程序
  28. public class Main {
  29. public static void main(String[] args) {
  30. // 创建实体列表,模拟树形结构
  31. List<Entity> entities = Arrays.asList(
  32. new Entity("1", null, "Root"), // 根节点
  33. new Entity("2", "1", "Child 1"), // Child 1, 父节点为Root
  34. new Entity("3", "1", "Child 2"), // Child 2, 父节点为Root
  35. new Entity("4", "2", "Grandchild 1") // Grandchild 1, 父节点为Child 1
  36. );
  37. // 创建树构建器实例
  38. TreeBuilder<Entity> treeBuilder = new TreeBuilder<>();
  39. // 构建树,传入实体列表及提取ID和父ID的函数
  40. TreeNode<Entity> tree = treeBuilder.buildTree(
  41. entities,
  42. Entity::getId, // 提取ID
  43. Entity::getParentId // 提取父ID
  44. );
  45. // 打印树结构
  46. printTree(tree, 0);
  47. }
  48. // 递归打印树结构的辅助方法
  49. private static void printTree(TreeNode<Entity> node, int level) {
  50. if (node == null) return; // 如果节点为空,直接返回
  51. // 打印当前节点的名称,缩进显示层级
  52. System.out.println(" ".repeat(level) + node.getData().getName());
  53. // 递归打印所有子节点
  54. for (TreeNode<Entity> child : node.getChildren()) {
  55. printTree(child, level + 1);
  56. }
  57. }
  58. }
复制代码

代码注释说明:

Entity类:每个字段和方法都有注释,说明其用途和功能。

Main类

  • 实体列表中每个节点的构造都有注释,解释其层级关系。
  • 构建树的步骤清晰描述,便于理解。

printTree方法:详细说明其递归逻辑和输出格式。

到此这篇关于Java实现公用实体类转Tree结构的文章就介绍到这了,更多相关Java公用实体类转Tree结构内容请搜索晓枫资讯以前的文章或继续浏览下面的相关文章希望大家以后多多支持晓枫资讯!


免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!
晓枫资讯-科技资讯社区-免责声明
免责声明:以上内容为本网站转自其它媒体,相关信息仅为传递更多信息之目的,不代表本网观点,亦不代表本网站赞同其观点或证实其内容的真实性。
      1、注册用户在本社区发表、转载的任何作品仅代表其个人观点,不代表本社区认同其观点。
      2、管理员及版主有权在不事先通知或不经作者准许的情况下删除其在本社区所发表的文章。
      3、本社区的文章部分内容可能来源于网络,仅供大家学习与参考,如有侵权,举报反馈:点击这里给我发消息进行删除处理。
      4、本社区一切资源不代表本站立场,并不代表本站赞同其观点和对其真实性负责。
      5、以上声明内容的最终解释权归《晓枫资讯-科技资讯社区》所有。
http://bbs.yzwlo.com 晓枫资讯--游戏IT新闻资讯~~~

  离线 

TA的专栏

等级头衔

等級:晓枫资讯-列兵

在线时间
0 小时

积分成就
威望
0
贡献
0
主题
0
精华
0
金钱
16
积分
12
注册时间
2022-12-25
最后登录
2022-12-25

发表于 2025-1-1 12:10:53 | 显示全部楼层
感谢楼主分享。
http://bbs.yzwlo.com 晓枫资讯--游戏IT新闻资讯~~~

  离线 

TA的专栏

等级头衔

等級:晓枫资讯-列兵

在线时间
0 小时

积分成就
威望
0
贡献
0
主题
0
精华
0
金钱
18
积分
16
注册时间
2022-12-25
最后登录
2022-12-25

发表于 2025-1-11 03:04:24 | 显示全部楼层
路过,支持一下
http://bbs.yzwlo.com 晓枫资讯--游戏IT新闻资讯~~~

  离线 

TA的专栏

等级头衔

等級:晓枫资讯-列兵

在线时间
0 小时

积分成就
威望
0
贡献
0
主题
0
精华
0
金钱
26
积分
32
注册时间
2022-12-27
最后登录
2022-12-27

发表于 2025-10-16 07:20:25 | 显示全部楼层
顶顶更健康!!!
http://bbs.yzwlo.com 晓枫资讯--游戏IT新闻资讯~~~
严禁发布广告,淫秽、色情、赌博、暴力、凶杀、恐怖、间谍及其他违反国家法律法规的内容。!晓枫资讯-社区
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

1楼
2楼
3楼
4楼

手机版|晓枫资讯--科技资讯社区 本站已运行

CopyRight © 2022-2025 晓枫资讯--科技资讯社区 ( BBS.yzwlo.com ) . All Rights Reserved .

晓枫资讯--科技资讯社区

本站内容由用户自主分享和转载自互联网,转载目的在于传递更多信息,并不代表本网赞同其观点和对其真实性负责。

如有侵权、违反国家法律政策行为,请联系我们,我们会第一时间及时清除和处理! 举报反馈邮箱:点击这里给我发消息

Powered by Discuz! X3.5

快速回复 返回顶部 返回列表