速通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;
    }
}
相关推荐
W23035765737 小时前
经典算法:最长上升子序列(LIS)深度解析 C++ 实现
开发语言·c++·算法
minji...8 小时前
Linux 线程同步与互斥(三) 生产者消费者模型,基于阻塞队列的生产者消费者模型的代码实现
linux·运维·服务器·开发语言·网络·c++·算法
语戚9 小时前
力扣 968. 监控二叉树 —— 贪心 & 树形 DP 双解法递归 + 非递归全解(Java 实现)
java·算法·leetcode·贪心算法·动态规划·力扣·
skywalker_119 小时前
力扣hot100-7(接雨水),8(无重复字符的最长子串)
算法·leetcode·职场和发展
bIo7lyA8v10 小时前
算法稳定性分析中的输入扰动建模的技术9
算法
CoderCodingNo10 小时前
【GESP】C++三级真题 luogu-B4499, [GESP202603 三级] 二进制回文串
数据结构·c++·算法
sinat_2869451910 小时前
AI Coding 时代的 TDD:从理念到工程落地
人工智能·深度学习·算法·tdd
炽烈小老头10 小时前
【 每天学习一点算法 2026/04/12】x 的平方根
学习·算法
ASKED_201910 小时前
从排序到生成:腾讯广告算法大赛 2025 baseline解读
人工智能·算法