news 2026/6/10 15:30:18

代码随想录算法训练营day 13-14:二叉树初步,递归

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
代码随想录算法训练营day 13-14:二叉树初步,递归

(递归遍历和层序遍历比较简单,这里就不写了)

非递归遍历(逻辑的统一与非统一)

逻辑非统一遍历

前序:先右后左入栈

中序:一路向左 + 回溯

后序:最难,需要控制访问顺序(当然,如果用前序的逻辑,最后把结果集反转,要简单很多)

逻辑统一遍历

我们发现,上面的三种遍历,逻辑都不太一样,能不能把逻辑统一一下,只背一个模板呢?

这就需要我们模拟递归的函数栈

栈里放TreeNode,在当前节点入栈后,同时入栈一个 null 当作标记:

第一次遇到节点:先不输出,先安排好它将来的输出时机(null标记)

当从栈里弹出null时:说明下一个弹出的节点就是“该输出”的节点

入栈顺序和遍历顺序反着来即可,前序是根左右,那入栈顺序就是右左根,以此类推

习题思考

LeetCode 226.翻转二叉树

这一题比较简单,先反转再递归还是先递归再反转都行,先反转的逻辑比较直观清晰。

LeetCode 101.对称二叉树

注意该题递归时,左节点和右节点比较完毕以后,应该再比较的是:(左节点左子树,右节点右子树),(左节点右子树,右节点左子树),注意对称比较即可。

LeetCode 104.二叉树最大深度 / 111.二叉树最小深度

最大深度:递归遇到null就返回0,否则沿着左右子树继续往下走,取二者的max再加一,返回值即可,比较简单,也比较好理解。代码如下:

public int maxDepth(TreeNode root) { if(root == null) return 0; int leftDepth = maxDepth(root.left); int rightDepth = maxDepth(root.right); return Math.max(leftDepth,rightDepth) + 1; }

最小深度:最初可能会以为,把Math.max改成Math.min不就行了?

还真不行,这两题的隐含条件其实是不一样的,关键点在于:左右子树即使有一边是null的,也不影响“最大”这个概念,但是“最小”就不一样了。

最小深度隐含要求路径必须走到叶子节点,而 null 不是一条合法的路径,不能把null作为一个路径计数,然后return 0进行高度比较,因为你可能还没走到叶子节点。

随便举一个例子:只含2个节点的树,如果按最大深度的逻辑写最小深度,答案会是1,因为空子树高度是0。但正确答案应该是2,因为你应该比较叶子到根的路径

一句话总结差异:

最大深度:null 是高度为 0 的节点

最小深度:null 是不可通行的方向

这里也把最小深度代码贴出来,可以对比差异:

public int minDepth(TreeNode root) { if(root == null) return 0; if(root.left == null && root.right == null) return 1; if(root.left == null) return minDepth(root.right) + 1; if(root.right == null) return minDepth(root.left) + 1; return Math.min(minDepth(root.left),minDepth(root.right)) + 1; }
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/6/9 2:55:04

Skyvern智能自动化工具完整使用指南

Skyvern智能自动化工具完整使用指南 【免费下载链接】skyvern 项目地址: https://gitcode.com/GitHub_Trending/sk/skyvern 在现代业务流程中,浏览器自动化已成为提高效率和减少重复劳动的关键技术。Skyvern作为一款AI驱动的智能自动化工具,能够…

作者头像 李华
网站建设 2026/6/9 22:15:35

智能代理驱动的自动化工具:从数据提取到业务流程重构

智能代理驱动的自动化工具:从数据提取到业务流程重构 【免费下载链接】skyvern 项目地址: https://gitcode.com/GitHub_Trending/sk/skyvern 你是否曾经为了一个简单的数据抓取任务,不得不编写数百行爬虫代码,结果网站前端一更新&…

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

开发者必看:集成EmotiVoice到App的API调用方式

开发者必看:集成EmotiVoice到App的API调用方式 在智能语音助手越来越“懂人心”的今天,用户早已不再满足于那种机械复读机式的回应。你有没有遇到过这样的场景:游戏里NPC一本正经地说“我好害怕”,语气却像在播报天气&#xff1f…

作者头像 李华
网站建设 2026/6/9 21:34:55

流媒体音频处理实战指南:从延迟优化到双向通话

你是否在开发流媒体应用时遇到过这些问题:音频延迟让人无法忍受,双向通话时声音断断续续,或者在不同设备上音频格式不兼容?作为一名音视频开发者,我深知这些痛点的困扰。今天,我将分享一套完整的流媒体音频…

作者头像 李华
网站建设 2026/6/10 13:58:45

KasmVNC完全攻略:浏览器远程桌面零基础入门指南

还在为传统远程控制软件的复杂配置而头疼吗?KasmVNC作为革命性的Web VNC解决方案,让你摆脱客户端安装的束缚,仅需浏览器即可畅享远程桌面体验。本文将手把手教你从零开始,快速掌握这一现代化桌面共享工具的完整使用流程。 【免费下…

作者头像 李华
网站建设 2026/6/10 13:58:36

预算有限 vs 求职加码:应届生如何避开AI认证“高费用低价值”陷阱?

一、 市场现状:机遇与选择困境并存 当前,人工智能技术正驱动新一轮产业变革,也深刻影响着就业市场。第三方调研数据显示,2023年人工智能相关岗位的求职竞争较为激烈。与此同时,超过半数的相关招聘启事会提及“具备AI基…

作者头像 李华