news 2026/4/23 10:28:47

day145—递归—二叉树的右视图(LeetCode-199)

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
day145—递归—二叉树的右视图(LeetCode-199)

题目描述

给定一个二叉树的根节点root,想象自己站在它的右侧,按照从顶部到底部的顺序,返回从右侧所能看到的节点值。

示例 1:

输入:root = [1,2,3,null,5,null,4]

输出:[1,3,4]

解释:

示例 2:

输入:root = [1,2,3,4,null,null,null,5]

输出:[1,3,4,5]

解释:

示例 3:

输入:root = [1,null,3]

输出:[1,3]

示例 4:

输入:root = []

输出:[]

提示:

  • 二叉树的节点个数的范围是[0,100]
  • -100 <= Node.val <= 100

解决方案:

这段代码的核心功能是获取二叉树的右视图(即从二叉树右侧观察能看到的节点值,按从上到下的顺序输出),采用「递归 + 前序遍历(优先访问右子树)」的思路,通过深度标记记录每一层的第一个(最右侧)节点,时间复杂度O(n)n为节点数),空间复杂度O(h)h为树的高度),是该问题的经典递归解法。

核心逻辑

代码的核心思路是 “优先遍历右子树,每一层只记录第一个访问到的节点(即最右侧节点)”,通过深度和结果数组的长度关联来实现:

  1. 全局结果数组初始化:定义ans数组保存右视图节点值,初始为空;
  2. 递归辅助函数f:参数为当前节点node和当前深度depth
    • 边界条件:若当前节点为空,直接返回;
    • 深度更新:当前节点非空时,深度+1(表示当前节点所在层);
    • 记录最右侧节点:若ans数组的长度小于当前深度(说明该层还未记录任何节点),将当前节点值加入ans(因优先遍历右子树,这是该层第一个被访问的节点,即最右侧节点);
    • 优先递归右子树:先遍历当前节点的右子树,再遍历左子树(保证每一层先访问右节点);
  3. 主函数触发遍历:调用f(root, 0)(初始深度为 0,未访问任何节点),最终返回ans即为右视图结果。

总结

  1. 核心思路:利用 “优先遍历右子树 + 深度标记”,让每一层的第一个节点就是最右侧节点,仅记录该节点即可;
  2. 关键细节:ans.size() < depth是判断 “是否为该层第一个节点” 的核心条件,确保每一层只记录一个节点;
  3. 效率特点:每个节点仅遍历一次,时间O(n);递归栈空间取决于树的高度,平衡树为O(log n),退化为链表时为O(n)

函数源码:

/** * Definition for a binary tree node. * struct TreeNode { * int val; * TreeNode *left; * TreeNode *right; * TreeNode() : val(0), left(nullptr), right(nullptr) {} * TreeNode(int x) : val(x), left(nullptr), right(nullptr) {} * TreeNode(int x, TreeNode *left, TreeNode *right) : val(x), left(left), right(right) {} * }; */ class Solution { public: vector<int> ans={}; void f(TreeNode* node,int depth){ if(!node) return; depth+=1; if(ans.size()<depth){ ans.push_back(node->val); } f(node->right,depth); f(node->left,depth); } vector<int> rightSideView(TreeNode* root) { f(root,0); return ans; } };
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/18 12:01:39

提示工程架构师必学:用Few-shot Learning增强提示情境感知的AI技巧

提示工程架构师必学:用Few-shot Learning增强提示情境感知的AI技巧 引言:为什么你的AI总是“get不到”上下文? 作为提示工程架构师,你可能遇到过这样的场景: 让AI写一封商务投诉回复邮件,结果它用了“嗨,哥们”这种口语化表达; 让AI解决Python性能优化问题,它却给出…

作者头像 李华
网站建设 2026/4/20 23:20:58

第一、二、三章 习题总结

习题 2-6&#xff08;P35&#xff09;用1,2,3&#xff0c;&#xff0c;9 组成3个三位数 abc &#xff0c; def 和 ghi &#xff0c;每个数字恰好使用一次&#xff0c;要求 abc &#xff1a; def &#xff1a; ghi 1:2:3 。按照“abc def ghi”的格式输出所有解&#xff0c;每行…

作者头像 李华
网站建设 2026/4/18 6:59:07

什么是LED驱动?

LED 驱动芯片&#xff08;LED Driver IC&#xff09;是现代照明和显示系统中的核心部件。简单来说&#xff0c;它的作用是将不稳定的电源电压&#xff08;如电池或市电整流后的电压&#xff09;转换为 LED 所需的恒定电流。以下是关于 LED 驱动芯片的功能、选型参数及拓扑结构的…

作者头像 李华
网站建设 2026/4/18 9:17:43

Python 实现生成式 AI 模型的部署与优化

友友们好! 我是Echo_Wish,我的的新专栏《Python进阶》以及《Python!实战!》正式启动啦!这是专为那些渴望提升Python技能的朋友们量身打造的专栏,无论你是已经有一定基础的开发者,还是希望深入挖掘Python潜力的爱好者,这里都将是你不可错过的宝藏。 在这个专栏中,你将会…

作者头像 李华
网站建设 2026/4/22 2:00:05

AI×医学影像:从像素到诊断洞察的落地之路

AI医学影像:从像素到诊断洞察的落地之路 如何用 AI 做生物医学图像处理 作者|Echo_Wish 一、引子:医学图像处理不是图像“修修图”,而是救命 说在前面一句很接地气也很真诚的话: 医学图像处理,是帮助医生更快、更准、更稳地发现病灶。不是炫酷大片特效。 你别看 CT、M…

作者头像 李华
网站建设 2026/4/20 7:36:32

vscode的.vscode文件记录

tasks.json&#xff1a;控制如何编译你的代码&#xff08;加 -I参数&#xff09; launch.json&#xff1a;控制如何调试你的代码&#xff08;指定调试器路径&#xff09;launch.json文件{"version": "0.2.0","configurations": [{"name&quo…

作者头像 李华