★102. 二叉树的层序遍历

102. 二叉树的层序遍历

很巧妙的,又学习了一种层次遍历的方法,就是说根据当前的队列的长度去遍历,遍历的当前队列的长度就是该层次的节点个数。

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<List<Integer>> levelOrder(TreeNode root) {
        List<List<Integer>> levelOrderList = new ArrayList<>();
        if(root == null) return levelOrderList;
        Queue<TreeNode> queue = new LinkedList<>();    //用于做队列,遍历整棵树
        List<Integer> list = new ArrayList<>();     // 用于存储用队列遍历树的val
        queue.add(root);
        while(queue.size()!=0) {
        //    System.out.println("当前队列的长度" + queue.size());
            int l = queue.size();
            for(int i=0;i<l; i++) {
                TreeNode front = queue.poll();   //LinkedList的poll方法可以取出第一个元素的值。
                list.add(front.val);
                if(front.left!=null) queue.add(front.left);
                if(front.right!=null) queue.add(front.right);
            }
/*             System.out.print("当前放入的元素为");
            Iterator iterator = list.iterator();
            while(iterator.hasNext()){
                System.out.print(iterator.next() + " ");
            }
            System.out.println(); */
            levelOrderList.add(list);
            list = new ArrayList<Integer>();
        }
        return levelOrderList;
    }
}
相关推荐
lmy2012110813 分钟前
提高:图论:强连通分量 图的遍历
c++·算法·图论·强联通分量
人类群星闪耀时32 分钟前
破解 N 皇后 II:位运算的高效艺术
python·算法·数学建模
Demons_kirit34 分钟前
LeetCode 1863.找出所有子集的异或总和再求和
数据结构·算法·leetcode
竹下为生44 分钟前
LeetCode --- 443周赛
算法·leetcode·职场和发展
green5+11 小时前
LeetCode18四数之和
java·开发语言·算法
雾里看山1 小时前
算法思想之双指针(一)
算法·leetcode·推荐算法
2401_827499991 小时前
leetcode-热题100(3)
数据结构·算法·leetcode
lzjava20241 小时前
Redis数据结构之Set
java·数据结构·redis
·醉挽清风·2 小时前
学习笔记—C++—入门基础()
c语言·开发语言·c++·笔记·学习·算法
百渡ovO2 小时前
【蓝桥杯】每日练习 Day21
c++·算法·蓝桥杯