102. 二叉树的层序遍历 队列+迭代

102. 二叉树的层序遍历

已解答

中等

相关标签

相关企业

给你二叉树的根节点 root ,返回其节点值的 层序遍历 。 (即逐层地,从左到右访问所有节点)。

示例 1:

复制代码
输入:root = [3,9,20,null,null,15,7]
输出:[[3],[9,20],[15,7]]

示例 2:

复制代码
输入:root = [1]
输出:[[1]]

示例 3:

复制代码
输入:root = []
输出:[]

提示:

  • 树中节点数目在范围 [0, 2000]
  • -1000 <= Node.val <= 1000

队列+迭代

java 复制代码
public List<List<Integer>> levelOrder(TreeNode root) {
        List<List<Integer>> resultList = new ArrayList<>();
        if(root == null){
            return resultList;
        }
        //迭代实现
        //把根节点装进队列里面
        Queue<TreeNode> que = new LinkedList<>();
        que.add(root);
        //que.offer(root);

        while(!que.isEmpty()){
            List<Integer> itemList = new ArrayList<>();
            int len = que.size();

            while(len > 0){
                //装配一层的结果集
                TreeNode tempNode = que.poll();
                //拿到值
                itemList.add(tempNode.val);
                
                //拿到值后里面查看当前节点的左右节点是否存在,存在装进去 随着len的实时更新。                    
                //会逐渐遍历 len用于找到队列哪些节点是当前层
                if(tempNode.left != null){que.add(tempNode.left);}
                if(tempNode.right != null){que.add(tempNode.right);}
                len--;
            }
            resultList.add(itemList);
        }
        return resultList;
    }
相关推荐
trueEve21 分钟前
SQL,力扣题目1369,获取最近第二次的活动
算法·leetcode·职场和发展
天若有情67325 分钟前
c++框架设计展示---提高开发效率!
java·c++·算法
ahadee32 分钟前
蓝桥杯每日真题 - 第19天
c语言·vscode·算法·蓝桥杯
Reese_Cool43 分钟前
【数据结构与算法】排序
java·c语言·开发语言·数据结构·c++·算法·排序算法
加密新世界1 小时前
优化 Solana 程序
人工智能·算法·计算机视觉
djk88881 小时前
.net将List<实体1>的数据转到List<实体2>
数据结构·list·.net
不爱说话郭德纲2 小时前
探索LLM前沿,共话科技未来
人工智能·算法·llm
搬砖的小码农_Sky2 小时前
C语言:结构体
c语言·数据结构
飞升不如收破烂~2 小时前
redis的map底层数据结构 分别什么时候使用哈希表(Hash Table)和压缩列表(ZipList)
算法·哈希算法
九圣残炎2 小时前
【从零开始的LeetCode-算法】3354. 使数组元素等于零
java·算法·leetcode