news 2026/6/14 22:01:15

数据结构之递归-如何巧妙利用递归函数的返回值

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
数据结构之递归-如何巧妙利用递归函数的返回值

下面以一个例题为例进行阐述。

给定一棵二叉树,返回所有表示从根结点到叶子结点路径的字符串。

解析:该过程用递归实现更好理解和处理,要得到由1为根,5和3为叶子节点的所有路径组成的字符串,我们只需要用1->拼接上其左右子树对应的路径即可,于是问题就向下延伸,变成了分别找以2和3为根结点的路径字符串,以此类推,直到树的叶子节点。这个过程是一个压栈(非叶子节点)和弹栈的过程(叶子节点),弹栈后就露出叶子节点对应的父节点(即临时根结点),之后开始组装需要字符串,待该父节点的所有子树的字符串都组装好了,逐步回溯到最终的根结点,完成最后的拼接。见下图二叉树,

输出结果为[“1->2->5”,“1->3”]。

import java.util.LinkedList; import java.util.List; public class LC257 { // 利用递归算法和回溯的思想,这是利用树的深度优先遍历 public List<String> binaryTreePaths(TreeNode root) { List<String> result = new LinkedList<String>(); // 递归终止条件1 if (null == root) return result; // 递归终止条件2,将叶子结点添加中间结果中,以便该叶子节点的父节点拼接临时字符串用 if (null == root.left && null == root.right) { result.add(String.valueOf(root.val)); return result; } // 递归处理当前结点的左子树 List<String> resultL = binaryTreePaths(root.left); // 将当前结点与其左子树结点连接 for (int l = 0; l < resultL.size(); ++l) result.add(String.valueOf(root.val) + "->" + resultL.get(l)); // 递归处理当前结点的右子树 List<String> resultR = binaryTreePaths(root.right); // 将当前结点与其右子树结点连接 for (int r = 0; r < resultR.size(); ++r) result.add(String.valueOf(root.val) + "->" + resultR.get(r)); return result; } public static void main(String[] args) { TreeNode root = new TreeNode(1); root.left = new TreeNode(2); root.right = new TreeNode(3); root.left.left = new TreeNode(4); root.left.right = new TreeNode(5); root.right.left = new TreeNode(6); System.out.println("result=" + new LC257().binaryTreePaths(root)); } }
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/6/15 7:30:46

43、awk语言的演变、扩展与gawk安装指南

awk语言的演变、扩展与gawk安装指南 1. SVR4与POSIX awk的变化 1992年的POSIX命令语言和实用工具标准为awk语言带来了一系列变化: - 使用 -W 来设置特定于实现的选项。 - 利用 CONVFMT 控制数字到字符串的转换。 - 引入了数字字符串的概念,并制定了更严格的比较规则。 …

作者头像 李华
网站建设 2026/6/15 5:26:14

【完整源码+数据集+部署教程】儿童动画标记检测系统源码分享[一条龙教学YOLOV8标注好的数据集一键训练_70+全套改进创新点发刊_Web前端展示]

一、背景意义 随着信息技术的迅猛发展&#xff0c;计算机视觉领域的研究日益受到关注&#xff0c;尤其是在物体检测和识别方面。儿童动画作为一种重要的文化产品&#xff0c;不仅在娱乐方面具有广泛的影响力&#xff0c;还在教育和心理发展中扮演着不可或缺的角色。近年来&…

作者头像 李华
网站建设 2026/6/9 16:28:20

【完整源码+数据集+部署教程】浮标检测系统源码分享[一条龙教学YOLOV8标注好的数据集一键训练_70+全套改进创新点发刊_Web前端展示]

一、背景意义 随着全球航运业和水上活动的快速发展&#xff0c;浮标作为重要的水上标识和导航工具&#xff0c;其检测与识别的准确性显得尤为重要。浮标不仅在航道标示、气象监测、海洋环境保护等领域发挥着重要作用&#xff0c;还在水上运动、渔业管理等方面具有广泛的应用。因…

作者头像 李华
网站建设 2026/6/14 18:58:25

Snort 入侵检测系统搭建指南

一、安装准备&#xff1a;环境依赖安装 在 CentOS7 系统中搭建 Snort&#xff0c;需先安装必备依赖库与拓展包&#xff0c;确保后续安装顺利进行。 复现平台 天枢一体化虚拟仿真平台 操作系统 CentOS7 1.1 基础依赖库安装 执行以下命令安装核心依赖&#xff1a; sudo yum…

作者头像 李华
网站建设 2026/6/11 12:33:22

JSP中如何利用多线程技术实现大文件并行上传?

大文件传输系统解决方案 作为浙江IT行业软件公司项目负责人&#xff0c;我们面临的大文件传输需求具有很高的技术挑战性。以下是我针对该需求的专业解决方案分析。 需求分析总结 超大文件传输&#xff1a;单文件100GB&#xff0c;文件夹层级结构保持高稳定性&#xff1a;支持…

作者头像 李华
网站建设 2026/6/10 12:17:15

wangEditor处理word文档超链接自动检测功能

【企业级富文本编辑器功能扩展项目纪实——从需求分析到阿里云OSS集成】 2023年X月X日 周X 上海徐汇区 一、需求拆解与核心约束 作为前端工程师&#xff0c;近期接到客户紧急需求&#xff1a;在现有Vue2 wangEditor4的后台系统中新增三大功能&#xff1a; Word粘贴增强&…

作者头像 李华