
离线 TA的专栏
- 打卡等级:即来则安
- 打卡总天数:16
- 打卡月天数:0
- 打卡总奖励:221
- 最近打卡:2024-07-11 01:01:50
|
工具类
- import java.util.*;
- import java.util.function.Function;
- import java.util.stream.Collectors;
-
- // 树节点类,用于存储树中的每个元素
- class TreeNode<T> {
- private T data; // 节点存储的数据
- private List<TreeNode<T>> children = new ArrayList<>(); // 子节点列表
-
- // 构造函数,初始化节点数据
- public TreeNode(T data) {
- this.data = data;
- }
-
- // 添加子节点
- public void addChild(TreeNode<T> child) {
- children.add(child);
- }
-
- // 获取当前节点的数据
- public T getData() {
- return data;
- }
-
- // 获取当前节点的所有子节点
- public List<TreeNode<T>> getChildren() {
- return children;
- }
- }
-
- // 树构建器类,负责从列表构建树形结构
- class TreeBuilder<T> {
- // buildTree方法,构建树形结构
- public TreeNode<T> buildTree(List<T> items, Function<T, String> idExtractor, Function<T, String> parentIdExtractor) {
- // 创建一个映射,将每个节点的ID映射到对应的TreeNode对象
- Map<String, TreeNode<T>> nodeMap = items.stream()
- .map(item -> new TreeNode<>(item)) // 将每个元素转换为TreeNode
- .collect(Collectors.toMap(node -> idExtractor.apply(node.getData()), Function.identity()));
-
- TreeNode<T> root = null; // 用于存储根节点
-
- // 遍历每个元素,建立父子关系
- for (T item : items) {
- String id = idExtractor.apply(item); // 获取当前节点的ID
- String parentId = parentIdExtractor.apply(item); // 获取父节点的ID
- TreeNode<T> node = nodeMap.get(id); // 获取当前节点
-
- if (parentId == null) {
- root = node; // 假设只有一个根节点
- } else {
- TreeNode<T> parentNode = nodeMap.get(parentId); // 获取父节点
- if (parentNode != null) {
- parentNode.addChild(node); // 将当前节点添加到父节点的子节点列表中
- }
- }
- }
-
- return root; // 返回构建的树的根节点
- }
- }
复制代码
注释说明:
TreeNode类:
- 每个字段和方法都有注释,说明其用途。
- 包含构造函数、添加子节点的方法以及获取数据和子节点的方法。
TreeBuilder类:
- buildTree方法的逻辑注释清晰,解释了每一步的目的。
- 使用映射将每个实体转换为树节点,并建立父子关系。
代码示例
- import java.util.Arrays;
- import java.util.List;
-
- // 实体类,用于表示树节点的数据
- class Entity {
- private String id; // 节点ID
- private String parentId; // 父节点ID
- private String name; // 节点名称
-
- // 构造函数
- public Entity(String id, String parentId, String name) {
- this.id = id;
- this.parentId = parentId;
- this.name = name;
- }
-
- // 获取节点ID
- public String getId() {
- return id;
- }
-
- // 获取父节点ID
- public String getParentId() {
- return parentId;
- }
-
- // 获取节点名称
- public String getName() {
- return name;
- }
- }
-
- // 主程序
- public class Main {
- public static void main(String[] args) {
- // 创建实体列表,模拟树形结构
- List<Entity> entities = Arrays.asList(
- new Entity("1", null, "Root"), // 根节点
- new Entity("2", "1", "Child 1"), // Child 1, 父节点为Root
- new Entity("3", "1", "Child 2"), // Child 2, 父节点为Root
- new Entity("4", "2", "Grandchild 1") // Grandchild 1, 父节点为Child 1
- );
-
- // 创建树构建器实例
- TreeBuilder<Entity> treeBuilder = new TreeBuilder<>();
-
- // 构建树,传入实体列表及提取ID和父ID的函数
- TreeNode<Entity> tree = treeBuilder.buildTree(
- entities,
- Entity::getId, // 提取ID
- Entity::getParentId // 提取父ID
- );
-
- // 打印树结构
- printTree(tree, 0);
- }
-
- // 递归打印树结构的辅助方法
- private static void printTree(TreeNode<Entity> node, int level) {
- if (node == null) return; // 如果节点为空,直接返回
-
- // 打印当前节点的名称,缩进显示层级
- System.out.println(" ".repeat(level) + node.getData().getName());
-
- // 递归打印所有子节点
- for (TreeNode<Entity> child : node.getChildren()) {
- printTree(child, level + 1);
- }
- }
- }
复制代码
代码注释说明:
Entity类:每个字段和方法都有注释,说明其用途和功能。
Main类:
- 实体列表中每个节点的构造都有注释,解释其层级关系。
- 构建树的步骤清晰描述,便于理解。
printTree方法:详细说明其递归逻辑和输出格式。
到此这篇关于Java实现公用实体类转Tree结构的文章就介绍到这了,更多相关Java公用实体类转Tree结构内容请搜索晓枫资讯以前的文章或继续浏览下面的相关文章希望大家以后多多支持晓枫资讯! 免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作! |
晓枫资讯-科技资讯社区-免责声明
免责声明:以上内容为本网站转自其它媒体,相关信息仅为传递更多信息之目的,不代表本网观点,亦不代表本网站赞同其观点或证实其内容的真实性。
1、注册用户在本社区发表、转载的任何作品仅代表其个人观点,不代表本社区认同其观点。
2、管理员及版主有权在不事先通知或不经作者准许的情况下删除其在本社区所发表的文章。
3、本社区的文章部分内容可能来源于网络,仅供大家学习与参考,如有侵权,举报反馈:  进行删除处理。
4、本社区一切资源不代表本站立场,并不代表本站赞同其观点和对其真实性负责。
5、以上声明内容的最终解释权归《晓枫资讯-科技资讯社区》所有。
|