LeetCode--513.找树左下角的值(二叉树)

题目描述

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

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

示例 1:

复制代码
输入: root = [2,1,3]
输出: 1

示例 2:

复制代码
输入: [1,2,3,4,null,5,6,null,null,7]
输出: 7

提示:

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

代码

迭代法

java 复制代码
/**
 * Definition for a binary tree node.
 * public class TreeNode {
 *     int val;
 *     TreeNode left;
 *     TreeNode right;
 *     TreeNode() {}
 *     TreeNode(int val) { this.val = val; }
 *     TreeNode(int val, TreeNode left, TreeNode right) {
 *         this.val = val;
 *         this.left = left;
 *         this.right = right;
 *     }
 * }
 */
class Solution {

    // 迭代法 层序遍历
    public int findBottomLeftValue(TreeNode root) {
        int result = root.val;
        if(root.left==null && root.right==null) return result;
        // 分层存放
        Queue<TreeNode> que = new ArrayDeque<>();
        que.add(root);
        while(!que.isEmpty()){
            int size = que.size();
            result = que.peek().val;
            for(int i=0; i<size; i++){
                TreeNode node = que.poll();
                if(node.left != null) que.add(node.left);
                if(node.right != null) que.add(node.right);
            }
        }
        return result;
    }
}

递归法

java 复制代码
/**
 * Definition for a binary tree node.
 * public class TreeNode {
 *     int val;
 *     TreeNode left;
 *     TreeNode right;
 *     TreeNode() {}
 *     TreeNode(int val) { this.val = val; }
 *     TreeNode(int val, TreeNode left, TreeNode right) {
 *         this.val = val;
 *         this.left = left;
 *         this.right = right;
 *     }
 * }
 */
class Solution {

    public int result;

    public int maxDepth=0;

    public void traverse(TreeNode node, int depth){
        if(node==null) return;
        // 前序遍历 先处理中间节点
        if(depth>maxDepth && node.left == null && node.right ==null){
            maxDepth = depth;
            result = node.val;
            return;
        }
        // 处理左节点
        if(node.left != null){
            depth++;
            traverse(node.left, depth);
            depth--; //回溯
        }
        // 处理右节点
        if(node.right != null){
            depth++;
            traverse(node.right, depth);
            depth--; //回溯
        }
        return;
    }

    public int findBottomLeftValue(TreeNode root) {
        traverse(root, 1);
        return result;
    }
}
相关推荐
敖正炀1 小时前
HashMap 红黑树化与退化
java
一个不知名程序员www1 小时前
算法学习入门---算法题DAY1
c++·算法
喜欢小苹果的码农1 小时前
xxl-job主流程分析
java
敖正炀1 小时前
HashMap 源码深度拆解(JDK 7→8)
java
Yeats_Liao1 小时前
物联网接入层技术剖析(二):epoll到底是怎么工作的
java·linux·网络·物联网·信息与通信
子琦啊1 小时前
构造函数、this指向和原型链机制
javascript·算法·贴图
WHS-_-20221 小时前
Millimeter Wave ISAC-SLAM: Framework and RFSoC Prototype
人工智能·算法·原型模式
吃好睡好便好1 小时前
在Matlab中绘制杆状图
开发语言·学习·算法·matlab·信息可视化
带带弟弟学爬虫__1 小时前
dyAPP数据采集-个人主页、发布、搜索、评论
服务器·python·算法·flutter·java-ee·django