zoukankan      html  css  js  c++  java
  • leetcode二叉树层序遍历

    利用队列存储下一层结构

    package binarytree.levelOrder.inordertraversal;
    
    import binarytree.untils.GenerateTreeNode;
    import binarytree.untils.TreeNode;
    
    import java.util.ArrayList;
    import java.util.LinkedList;
    import java.util.List;
    import java.util.Queue;
    
    /**
     * 102. 二叉树的层序遍历
     * 给你一个二叉树,请你返回其按 层序遍历 得到的节点值。 (即逐层地,从左到右访问所有节点)。
     * <p>
     * <p>
     * <p>
     * 示例:
     * 二叉树:[3,9,20,null,null,15,7],
     * <p>
     * 3
     * / \
     * 9  20
     * /  \
     * 15   7
     * 返回其层序遍历结果:
     * <p>
     * [
     * [3],
     * [9,20],
     * [15,7]
     * ]
     */
    public class LevelOrder {
        /**
         * 层序遍历
         * <p>
         * 1,2,3,4,5,6,7,8,9
         * <p>
         * 1,2,3,4,5,6,7,8,9
         * <p>
         * 思路,一层一层遍历,一边构建队列,一边记录上一层的数字
         *
         * @param root
         * @return
         */
        public static List<List<Integer>> levelOrder(TreeNode root) {
            List<List<Integer>> re = new ArrayList<>();
            if (root == null) {
                return re;
            }
            Queue<TreeNode> queue = new LinkedList();
            queue.offer(root);
            while (!queue.isEmpty()) {
                List<Integer> res = new ArrayList<>();
                int size = queue.size();//这里要用变量,否则 queue是动态变化的,无法确定循环次数
                for (int i = 0; i < size; i++) {
                    TreeNode treeNode = queue.poll();
                    res.add(treeNode.val);
                    if (treeNode.left != null) {
                        queue.add(treeNode.left);
                    }
                    if (treeNode.right != null) {
                        queue.add(treeNode.right);
                    }
    
                }
                re.add(res);
            }
    
            return re;
        }
    
    
        public static void main(String[] args) {
            Integer[] nums = {1, 2, 3, 4, 5, 6, 7};
            TreeNode treeNode = GenerateTreeNode.generateTreeNode(nums);
            levelOrder(treeNode);
            System.out.println();
        }
    }
    
    
  • 相关阅读:
    字符串-串的最大表示-后缀数组-1163. 按字典序排在最后的子串
    动态规划-买卖股票的最佳时机 V
    贪心-到达终点数字
    贪心-优先队列-模拟-任务调度器
    滑动窗口-区间统计
    快速排序-无序数组K小元素
    POJ 2299 Ultra-QuickSort【树状数组 ,逆序数】
    POJ 2976 Dropping tests【二分 最大化平均值】
    POJ 1064 Cable master 【二分答案】
    POJ 3190 Stall Reservations 【贪心 优先队列】
  • 原文地址:https://www.cnblogs.com/xiaoshahai/p/15683691.html
Copyright © 2011-2022 走看看