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]};
}
}
}