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);队列空间开销取决于树的宽度(最坏为最后一层节点数),是该问题的最优解法之一。

函数源码:

cpp 复制代码
/**
 * 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;
    }
};
相关推荐
cwplh10 分钟前
平衡树学习笔记
数据结构·笔记·学习·算法
wen__xvn18 分钟前
天梯赛L2刷题(也就写写水题骗骗自己了)
算法
EllinY21 分钟前
扩展欧几里得算法 exgcd 详解
c++·笔记·数学·算法·exgcd
AI科技星34 分钟前
三维网格—素数对偶性及其严格证明(全域数学·统一基态演化版)
算法·数学建模·数据挖掘
诸葛务农1 小时前
光电对抗:多模复合制导烟雾干扰外场试验及仿真(4)
人工智能·算法·光电对抗
WolfGang0073211 小时前
代码随想录算法训练营 Day39 | 动态规划 part12
算法·动态规划
阿Y加油吧1 小时前
动态规划经典题解:最长递增子序列 & 乘积最大子数组
算法·动态规划·代理模式
f3iiish1 小时前
3783. 整数的镜像距离 力扣
算法·leetcode
Not Dr.Wang4221 小时前
基于matlab的控制系统奈氏图及其稳定性分析
数据结构·算法·matlab
闻缺陷则喜何志丹1 小时前
【排序 离散化 二维前缀和】 P7149 [USACO20DEC] Rectangular Pasture S|普及+
c++·算法·排序·离散化·二维前缀和