news 2026/4/15 9:12:54

day151—双端队列—找树左下角的值(LeetCode-513)

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
day151—双端队列—找树左下角的值(LeetCode-513)

题目描述

给定一个二叉树的根节点root,请找出该二叉树的最底层 最左边节点的值。

假设二叉树中至少有一个节点。

示例 1:

输入:root = [2,1,3]输出:1

示例 2:

输入:[1,2,3,4,null,5,6,null,null,7]输出:7

提示:

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

解决方案:

这段代码的核心功能是找到二叉树最底层最左侧的节点值,采用「层序遍历(BFS)+ 优先入队右子节点」的技巧实现,时间复杂度O(n)n为节点数),空间复杂度O(n)(队列存储节点开销),是该问题的简洁高效解法。

核心逻辑

代码利用队列实现层序遍历,但通过调整子节点入队顺序(先右后左),让最后遍历到的节点恰好是 “最底层最左侧” 的节点,无需记录层数:

  1. 初始化
    • 用双端队列deq存储待遍历节点,初始加入根节点;
    • ans记录结果,初始化为根节点值(兜底空树 / 单节点场景);
  2. 层序遍历循环:只要队列非空,持续遍历:
    • 取出队列头部节点node,并更新ans为该节点的值;
    • 核心技巧:先将右子节点入队,再将左子节点入队(改变常规的 “先左后右” 顺序);
  3. 返回结果:遍历结束时,ans最后一次更新的值就是 “最底层最左侧” 节点的值(因为先遍历右节点,最后遍历到的必然是最底层最左节点)。

总结

  1. 核心思路:通过「先右后左」的入队顺序,让层序遍历的最后一个节点就是 “最底层最左侧” 节点,无需统计层数或记录每一层的第一个节点;
  2. 关键细节:队列遍历采用 “取头→更新结果→右子入队→左子入队” 的顺序,保证遍历到最底层时,最后一个节点是最左侧的;
  3. 效率特点:每个节点仅入队 / 出队一次,时间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: int findBottomLeftValue(TreeNode* root) { deque<TreeNode*> deq={root}; int ans=root->val; while(!deq.empty()){ TreeNode* node=deq.front(); deq.pop_front(); ans=node->val; if(node->right){ deq.push_back(node->right); } if(node->left){ deq.push_back(node->left); } } return ans; } };
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/9 0:07:25

智能写作解决方案:9款AI平台提升开题报告与论文撰写效率

在毕业论文季&#xff0c;高效完成开题报告和论文是很多学子的痛点。人工写作虽然灵活&#xff0c;但耗时耗力&#xff1b;而AI工具的兴起&#xff0c;能快速生成内容、优化重复率和AI痕迹。今天&#xff0c;我通过9款平台对比&#xff0c;帮你找出最适合的“学术搭档”。先从人…

作者头像 李华
网站建设 2026/4/3 8:23:01

IQuest-Coder-V1-40B多任务处理:并行编程辅助系统开发

IQuest-Coder-V1-40B多任务处理&#xff1a;并行编程辅助系统开发 1. 引言&#xff1a;面向下一代软件工程的智能编码范式 随着软件系统复杂度的持续攀升&#xff0c;传统编码辅助工具在理解上下文、推理逻辑演变和跨任务协同方面逐渐显现出局限性。尤其是在自主软件工程&…

作者头像 李华
网站建设 2026/4/10 16:41:31

Open Interpreter视频直播:弹幕分析脚本生成实战

Open Interpreter视频直播&#xff1a;弹幕分析脚本生成实战 1. 背景与场景引入 在当前AI技术快速演进的背景下&#xff0c;开发者和内容创作者对自动化工具的需求日益增长。尤其是在直播场景中&#xff0c;如何实时处理大量用户输入&#xff08;如弹幕&#xff09;&#xff…

作者头像 李华
网站建设 2026/4/13 19:38:33

用Z-Image-Turbo做社交媒体封面,效果炸裂

用Z-Image-Turbo做社交媒体封面&#xff0c;效果炸裂 在内容为王的时代&#xff0c;社交媒体的视觉呈现已成为吸引用户注意力的第一战场。无论是公众号推文、小红书笔记还是微博动态&#xff0c;一张高质量、风格统一且富有冲击力的封面图&#xff0c;往往能决定内容的点击率与…

作者头像 李华
网站建设 2026/4/11 3:55:21

QListView拖放功能在模型中的应用实例

让 QListView 真正“动”起来&#xff1a;拖放功能的模型级实战解析你有没有遇到过这样的场景&#xff1f;用户想要调整播放列表顺序&#xff0c;却只能靠上下按钮一步步挪&#xff1b;或者任务管理系统里&#xff0c;优先级重排要打开编辑框手动输入数字。这些操作不仅繁琐&am…

作者头像 李华