递归获取某个节点的儿子节点
java 代码:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 | public List<Department> getAllChildrenDepartmentsFlat(Long parentId) { List<Department> allDepartments = departmentRepository.findAll(); // 假设使用JPA的Repository来进行数据库操作 List<Department> allChildren = new ArrayList<>(); Department parent = departmentRepository.findById(parentId); if (parent != null ) { allChildren.add(parent); flattenChildren(allDepartments, parent, allChildren); } return allChildren; } private void flattenChildren(List<Department> allDepartments, Department parent, List<Department> flatList) { List<Department> children = allDepartments.stream() .filter(department -> department.getParentId().equals(parent.getId())) .collect(Collectors.toList()); for (Department child : children) { flatList.add(child); flattenChildren(allDepartments, child, flatList); } } |
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 无需6万激活码!GitHub神秘组织3小时极速复刻Manus,手把手教你使用OpenManus搭建本
· C#/.NET/.NET Core优秀项目和框架2025年2月简报
· 什么是nginx的强缓存和协商缓存
· 一文读懂知识蒸馏
· Manus爆火,是硬核还是营销?