代码随想录 Day15 - 二叉树(二)

简介: 代码随想录 Day15 - 二叉树(二)

作业题


层序遍历,类似 BFS 写法,遍历每一层的时候,添加下一层的节点到队列中,避免死循环,需要在每一层开始遍历之前,就记录一下节点数量,并且将结果记录到数组。

102. 二叉树的层序遍历

package jjn.carl.binary_tree;
import commons.BinaryTreeHelper;
import commons.TreeNode;
import java.util.*;
/**
 * @author Jiang Jining
 * @since 2023-07-12 23:40
 */
public class LeetCode102 {
    public List<List<Integer>> levelOrder(TreeNode root) {
        Queue<TreeNode> queue = new LinkedList<>();
        List<List<Integer>> result = new ArrayList<>();
        if (root == null) {
            return result;
        }
        queue.offer(root);
        while (!queue.isEmpty()) {
            int size = queue.size();
            List<Integer> level = new ArrayList<>();
            for (int i = 0; i < size; i++) {
                TreeNode poll = queue.poll();
                if (poll == null) {
                    continue;
                }
                level.add(poll.val);
                if (poll.left != null) {
                    queue.offer(poll.left);
                }
                if (poll.right != null) {
                    queue.offer(poll.right);
                }
            }
            result.add(level);
        }
        return result;
    }
    public static void main(String[] args) {
        List<Integer> input = new ArrayList<>();
        input.addAll(List.of(3, 9, 20));
        input.add(null);
        input.add(null);
        input.add(15);
        input.add(7);
        TreeNode root = BinaryTreeHelper.buildTree(input);
        List<List<Integer>> levelledOrder = new LeetCode102().levelOrder(root);
        System.out.println("levelledOrder = " + levelledOrder);
    }
}


226. 翻转二叉树

/**
 * 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 TreeNode invertTree(TreeNode root) {
        if (root == null) {
            return root;
        }
        TreeNode left = root.left;
        TreeNode right = root.right;
        root.left = invertTree(right);
        root.right = invertTree(left);
        return root;
    }
}


101. 对称二叉树

借助函数 isSymmetricPairs 来判断两棵子树是否对称,即树 1 的左节点和树 2 的右节点,树 2 的左节点和树 1 的右节点是否相等。

/**
 * 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 isSymmetric(TreeNode root) {
        if (root == null) {
            return true;
        }
        return isSymmetricPairs(root.left, root.right);
    }
    private boolean isSymmetricPairs(TreeNode left, TreeNode right) {
        if (left == null && right == null) {
            return true;
        }
        if (left == null || right == null) {
            return false;
        }
        if (left.val != right.val) {
            return false;
        }
        return isSymmetricPairs(left.left, right.right) && isSymmetricPairs(left.right, right.left);
    }
}

目录
相关文章
|
7月前
代码随想录——双指针(一)
代码随想录——双指针(一)
代码随想录 Day21 - 二叉树(七)
代码随想录 Day21 - 二叉树(七)
46 0
代码随想录 Day13 - 栈与队列(下)
代码随想录 Day13 - 栈与队列(下)
48 0
代码随想录 Day11 - 栈与队列(中)
代码随想录 Day11 - 栈与队列(中)
45 0
代码随想录 Day14 - 二叉树(一)
代码随想录 Day14 - 二叉树(一)
64 1
代码随想录 Day17 - 二叉树(四)
代码随想录 Day17 - 二叉树(四)
46 1
代码随想录 Day20 - 二叉树(六)
代码随想录 Day20 - 二叉树(六)
59 0
代码随想录 Day18 - 二叉树(五)
代码随想录 Day18 - 二叉树(五)
59 0
代码随想录 Day16 - 二叉树(三)
代码随想录 Day16 - 二叉树(三)
57 0
代码随想录 Day23 - 二叉树(九)
代码随想录 Day23 - 二叉树(九)
60 0