速通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;
    }
}
相关推荐
chushiyunen2 小时前
BM25稀疏检索算法笔记
笔记·算法·c#
芸忻2 小时前
day 23 第七章 回溯算法part02代码随想录算法训练营71期
算法
qq_334903152 小时前
C++中的装饰器模式高级应用
开发语言·c++·算法
窝子面2 小时前
LeetCode练题六:dfs与bfs
leetcode·深度优先·宽度优先
jyyyx的算法博客2 小时前
LC406. 基于身高重建队列【贪心】
算法
忙什么果2 小时前
class_weight=‘balanced‘缓解类别不平衡问题
算法·机器学习·支持向量机
灰色小旋风2 小时前
力扣14 最长公共前缀(C++)
java·数据结构·算法
努力学习的小廉2 小时前
我爱学算法之——floodfill算法(下)
学习·算法
2401_851272992 小时前
编译器内建函数使用
开发语言·c++·算法