2021.11.11 - SX07-17.找树左下角的值

1. 题目

在这里插入图片描述

2. 思路

(1) 递归

  • 利用递归函数遍历二叉树,返回值为int数组,第一个元素为左下角结点的深度,第二个元素为左下角结点的值。
  • 当遍历到叶子结点时,规定其深度为0,返回其深度和值;当遍历到有左右子树的结点时,比较其左右子树的左下角结点的深度,只有当右子树左下角结点的深度大于左子树左下角结点的深度时,才取右子树左下角的结点,否则,取左子树左下角的结点,返回左下角结点的深度加1和值;当遍历到只有左子树或只有右子树的结点时,返回左下角结点的深度加1和值。

3. 代码

public class Test {
    
    
    public static void main(String[] args) {
    
    
    }
}

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) {
    
    
        return recur(root)[1];
    }

    private int[] recur(TreeNode root) {
    
    
        if (root.left == null && root.right == null) {
    
    
            return new int[]{
    
    0, root.val};
        } else if (root.left != null && root.right != null) {
    
    
            int[] left = recur(root.left);
            int[] right = recur(root.right);
            if (left[0] >= right[0]) {
    
    
                return new int[]{
    
    left[0] + 1, left[1]};
            } else {
    
    
                return new int[]{
    
    right[0] + 1, right[1]};
            }
        } else if (root.left != null) {
    
    
            int[] left = recur(root.left);
            return new int[]{
    
    left[0] + 1, left[1]};
        } else {
    
    
            int[] right = recur(root.right);
            return new int[]{
    
    right[0] + 1, right[1]};
        }
    }
}

猜你喜欢

转载自blog.csdn.net/qq_44021223/article/details/121270275