速通Hot100-Day10——二叉树

今天这种关于二叉树中,判断是否是遍历当前节点的写法让我受学习。

不过,可能那种父亲角度理解的面试官喜欢吧。

222. 完全二叉树的节点个数

就是简单的递归求取节点,有点类似于求取树的高度了

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 countNodes(TreeNode root) {
        if(root == null) return 0;
        return getNode(root);
    }

    private int getNode(TreeNode cur) {
        if(cur == null) return 0;
        
        int left = getNode(cur.left);
        int right = getNode(cur.right);

        return left + right + 1;
    }
}

110. 平衡二叉树

平衡,最后需要统一判断是否左右子树高度的差值。

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 boolean isBalanced(TreeNode root) {
        if(root == null) return true;
        return traversal(root);
    }

    private boolean traversal(TreeNode cur) {
        if(cur == null) return true;

        boolean l = traversal(cur.left);
        boolean r = traversal(cur.right);
        int left = getDepth(cur.left);
        int right = getDepth(cur.right);
        int diff = Math.abs(left - right);
        return l && r && diff <= 1;
    }

    private int getDepth(TreeNode cur) {
        if(cur == null) return 0;

        int left = getDepth(cur.left);
        int right = getDepth(cur.right);
        return Math.max(left, right) + 1;
    }
}

257. 二叉树的所有路径

就是递归,理解递归的条件、出口、参数即可。

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 List<String> binaryTreePaths(TreeNode root) {
        List<String> paths = new ArrayList<>();
        if(root == null) return paths;

        dfs(root, "", paths);
        return paths;
    }

    private void dfs(TreeNode cur, String path, List<String> paths) {
        if(path.isEmpty()) {
            path = cur.val + "";
        } else {
            path = path + "->" + cur.val;
        }

        if(cur.left == null && cur.right == null) {
            paths.add(path);
            return;
        }

        if(cur.left != null) dfs(cur.left, path, paths);
        if(cur.right != null) dfs(cur.right, path, paths);
    }
}

112. 路径总和

这里存储两个队列,到当前节点就计算当前的总和totalSum,并非提前计算,所以会清楚一点。

那么要求一开始 sum 初始值 0;

如果想要提前计算,那么sum 初始值是 root.val

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 boolean hasPathSum(TreeNode root, int targetSum) {
        if(root == null) return false;

        LinkedList<TreeNode> q = new LinkedList<>();
        q.offer(root);
        LinkedList<Integer> sum = new LinkedList<>();
        sum.offer(0);

        while(!q.isEmpty()) {
            int curSize = q.size();
            while(curSize -- > 0) {
                TreeNode t = q.poll();
                int curSum = sum.poll();

                int totalSum = curSum + t.val;

                if(t.left == null && t.right == null && totalSum == targetSum) return true;
                if(t.left != null) {
                    q.offer(t.left);
                    sum.offer(totalSum);
                }
                if(t.right != null) {
                    q.offer(t.right);
                    sum.offer(totalSum);
                }
            }
        }
        return false;
    }
}

404. 左叶子之和

这个节点有点是站在父亲节点的角度去判断的,是否是左节点,然后是叶子节点。

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 sumOfLeftLeaves(TreeNode root) {
        if(root == null) return 0;
        LinkedList<TreeNode> q = new LinkedList<>();
        q.offer(root);

        int res = 0;
        while(!q.isEmpty()) {
            int curSize = q.size();
            for(int i = 0;i < curSize;i++) {
                TreeNode t = q.poll();
                if(t.left != null && t.left.left == null
                && t.left.right == null) res += t.left.val;
                if(t.left != null) q.offer(t.left);
                if(t.right != null) q.offer(t.right);
            }
        }

        return res;
    }
}

那么还有一种是,遍历当前节点才判断是否是左节点了。

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 sumOfLeftLeaves(TreeNode root) {
        if(root == null) return 0;
        LinkedList<TreeNode> q = new LinkedList<>();
        q.offer(root);
        LinkedList<Boolean> isLeft = new LinkedList<>();
        isLeft.offer(false);

        int res = 0;
        while(!q.isEmpty()) {
            int curSize = q.size();
            for(int i = 0;i < curSize;i++) {
                TreeNode t = q.poll();
                boolean flag = isLeft.poll();

                if(flag && t.left == null && t.right == null) res += t.val;

                if(t.left != null) {
                    q.offer(t.left);
                    isLeft.offer(true);
                }
                if(t.right != null) {
                    q.offer(t.right);
                    isLeft.offer(false);
                }
            }
        }

        return res;
    }
}

513. 找树左下角的值

这个层序,先加入右节点,再左节点,那么最后一个元素必然是个左下角。

所以只需要让 res 一直赋值即可。

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) {
        if(root == null) return 0;
        LinkedList<TreeNode> q = new LinkedList<>();
        q.offer(root);

        int res = 0;
        while(!q.isEmpty()) {
            int curSize = q.size();
            while(curSize-- > 0) {
                TreeNode t = q.poll();
                res = t.val;
                if(t.right != null) q.offer(t.right);
                if(t.left != null) q.offer(t.left);
            }
        }
        
        return res;
    }
}

如果是正常层序,那么就需要判断当前是否是第一个节点,那么才是左下角的点。

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) {
        if(root == null) return 0;
        LinkedList<TreeNode> q = new LinkedList<>();
        q.offer(root);

        int res = 0;
        while(!q.isEmpty()) {
            int curSize = q.size();
            for(int i = 0;i < curSize;i++){
                TreeNode t = q.poll();
                if(i == 0) res = t.val;
                if(t.left != null) q.offer(t.left);
                if(t.right != null) q.offer(t.right);
                
            }
        }
        
        return res;
    }
}
相关推荐
JieE21221 小时前
LeetCode 101. 对称二叉树|JS 递归 + 迭代双解法,彻底搞懂镜像判断
javascript·算法
JieE2122 天前
LeetCode 56. 合并区间|超清晰 JS 图解思路,面试高频区间题
javascript·算法·面试
Jack202 天前
HarmonyOS开发中错误处理策略:网络异常统一处理
算法
小小杨树2 天前
读懂色彩:拍照调色不再难
算法·计算机视觉·配色
JieE2123 天前
LeetCode 226. 翻转二叉树|JS 递归超详细拆解,二叉树入门经典题
javascript·算法
JieE2123 天前
LeetCode 104. 二叉树的最大深度|递归思路超详细拆解
javascript·算法
vivo互联网技术3 天前
CVPR 2026 | 全新强化学习框架 BeautyGRPO:重塑真实人像
算法·大模型·cvpr·影像
Darling噜啦啦3 天前
列表转树算法深度解析:从 Map 到 Reduce 的两种实现,面试高频考点
数据结构·算法·面试
用户497863050733 天前
(一)小红的数组操作
算法·编程语言