剑指Offer|LCR 045.找树左下角的值

LCR 045.找树左下角的值

给定一个二叉树的 根节点 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

法1:

分析:

定义两个队列queue1和queue2,默认将root加入queue1,令result默认为root.val。

如果queue1不为空,则遍历:

  • 将首元素出队列queue1,并将当前节点的左右孩子入队列(获取下层的节点);
  • 当queue1的长度为0 的时候,表明当前层次的节点都遍历结束,更新一下queue1为下一层次节点,queue2初始为空,判断queue1是否大于0 ,有节点的话需要更新一下result。
js 复制代码
 var findBottomLeftValue = function(root) {
    let queue1 = []; 
    let queue2 = []; 
    queue1.push(root);
    let result = root.val;

    while(queue1.length > 0){
        let node = queue1.shift(); // 移除第一个元素
        // 如果有左子节点,加入队列2
        if(node.left !== null){
            queue2.push(node.left);
        }

        if(node.right !== null){
            queue2.push(node.right);
        }

        // 如果当前队列为空,表示当前层已处理完毕
        if(queue1.length === 0){
            // 当前层处理完后,交换队列
            queue1 = queue2;
            queue2 = [];

            // 如果 queue1不为空,更新最左节点的值为当前队列的第一个节点
            if(queue1.length > 0){
                result = queue1[0].val;
            }
        }
    }
	return result;
};
相关推荐
kkeeper~5 小时前
0基础C语言积跬步之数据在内存中的存储
c语言·数据结构·算法
wabs6666 小时前
关于贪心算法的一些自我总结【力扣45.跳跃游戏II】【灵感来源:代码随想录】
算法·贪心算法·复盘
2401_876964137 小时前
【湖北专升本】2026湖北专升本真题PDF+备考资料汇总
数据结构·人工智能·经验分享·深度学习·算法·计算机视觉
zhangyao9403307 小时前
开发pc端时,表格的高度怎么设置才能铺满页面
前端·javascript·elementui
嗝o゚7 小时前
CANN GE 算子融合——融合算法与调度策略
算法·昇腾·cann·ge
小江的记录本7 小时前
【JVM虚拟机】垃圾回收GC:垃圾回收算法:标记-清除、标记-复制、标记-整理、分代收集(附《思维导图》+《面试高频考点清单》)
java·jvm·后端·python·算法·安全·面试
XinZong7 小时前
实测OpenClaw虾淘:全民工具AI时代,冷门非工具类的Skill还能出圈吗?
javascript
烛衔溟8 小时前
TypeScript 类的类型 —— 作为类型使用
javascript·ubuntu·typescript
之歆8 小时前
Day16_JavaScript 轮播图与事件工程实战(下篇)
服务器·开发语言·前端·javascript·网络·性能优化
kyriewen8 小时前
我关掉了Copilot:因为我写的代码出现在了别人的建议里
前端·javascript·ai编程