力扣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;
    }
}
相关推荐
tjl521314_214 分钟前
01C++ 分离编译与多文件编程
前端·c++·算法
_日拱一卒5 分钟前
LeetCode:23合并K个升序链表
java·数据结构·算法·leetcode·链表·职场和发展
cany10005 分钟前
C++ -- 泛型编程
java·开发语言·c++
lee_curry7 分钟前
第三章 jvm中的对象和执行引擎
java·jvm·执行引擎
哆啦刘小洋8 分钟前
【LeetCode每日一题】:2033(贪心+快速排序魔改)
算法·leetcode
wang09078 分钟前
Linux性能优化之文件系统基础介绍
java·linux·性能优化
WolfGang00732111 分钟前
代码随想录算法训练营 Day48 | 图论 part06
算法·图论
cheems952715 分钟前
[算法手记] 动态规划 ,二维费用限制背包问题如何处理
算法·动态规划
迷藏49417 分钟前
# 发散创新:用Locust实现高并发场景下的精准压力测试与性能调优实战在现代微服务架构中,**接口稳定性与响应速度**已成为衡量
java·python·微服务·架构·压力测试
空中海22 分钟前
Nacos 2: Spring Boot Demo 实战
java·spring boot·后端