力扣513 找树左下角的值 Java版本

文章目录


题目描述

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

解题思路

可以采用层序遍历的方法解决这个问题,下面代码中注释了

代码

java 复制代码
class Solution {
    //使用层序遍历,每遍历到新的一层的时候就更新一下结果为每层的第一个节点
    //最后结果保存的就是最左下角的节点
    public int findBottomLeftValue(TreeNode root) {
        Queue<TreeNode> queue = new LinkedList<>();
        int result = 0;
        if (root==null){
            return 0;
        }
        queue.offer(root);
        while (!queue.isEmpty()){
            int size = queue.size();
            for (int i = 0; i < size; i++) {
                TreeNode node = queue.poll();
                //如果是这一层的第一个节点就保留一下
                if (i==0){
                    result = node.val;
                }
                if (node.left!=null){
                    queue.offer(node.left);
                }
                if (node.right!=null){
                    queue.offer(node.right);
                }
            }
        }
        return result;
    }
}
相关推荐
一起养小猫几秒前
LeetCode100天Day5-最小长度子数组与三数之和
算法·leetcode·职场和发展
❀͜͡傀儡师2 分钟前
基于docker一键部署 x86的cpu_mem_hog 用于生成CPU和内存负载,用于服务器cpu和内存使用不达标的
java·服务器·docker
小龙报2 分钟前
【初阶数据结构】从 “数组升级” 到工程实现:动态顺序表实现框架的硬核拆解指南
c语言·数据结构·c++·算法·机器学习·信息与通信·visual studio
蜡笔大新7984 分钟前
IO流的认识(2)
java·ide·intellij-idea
多米Domi0118 分钟前
0x3f第九天复习(考研日)(10.57-14:00)
python·算法
廋到被风吹走14 分钟前
【Java】【JVM】OOM 原因、定位与解决方案
java·开发语言·jvm
byzh_rc16 分钟前
[模式识别-从入门到入土] 拓展-EM算法
算法·机器学习·概率论
努力学算法的蒟蒻18 分钟前
day41(12.22)——leetcode面试经典150
算法·leetcode·面试
苹果醋319 分钟前
vue + iview + vue-i18n中英翻译
java·运维·spring boot·mysql·nginx
liliangcsdn19 分钟前
Python拒绝采样算法优化与微调模拟
人工智能·算法·机器学习