041二叉树的层序遍历

二叉树的层序遍历

题目链接:https://leetcode.cn/problems/binary-tree-level-order-traversal/description/?envType=study-plan-v2\&envId=top-100-liked

我的解答:

复制代码
public List<List<Integer>> levelOrder(TreeNode root) {
    List<List<Integer>> ans = new ArrayList<>();
    if(root==null){
        return ans;
    }
    Queue<TreeNode> queue = new LinkedList<>();
    queue.offer(root);
    int cnt;//当前层的节点个数
    while(!queue.isEmpty()){
        cnt = queue.size();
        List<Integer> list = new ArrayList<>();
        while(cnt > 0){
            TreeNode node = queue.poll();
            list.add(node.val);
            cnt--;
            if(node.left != null){
                queue.offer(node.left);
            }
            if(node.right != null){
                queue.offer(node.right);
            }
        }
        ans.add(list);
    }
    return ans;
}

分析:代码的时间复杂度为O(n),空间复杂度为O(n)。解题思路:利用队列存储和拓展每一层的节点,首先将根节点入队,每轮拓展前先计算当前队列的大小,此时队列的大小就是当前层的节点总个数,假设为cnt,之后循环出队cnt个节点并将它们的左右节点按先左后右的顺序加入队列,重复此操作直到队列为空即可。

看了官方题解后的解答:

复制代码
//广度优先搜索(解题思路与我的解答一致)
//时间复杂度:O(n)
//空间复杂度:O(n)

分析:

​ 官方解答与我的解答一致,故不再赘述。

总结

  • 本题主要利用队列实现二叉树的广度优先搜索,解题思路较为简单。
相关推荐
谙弆悕博士1 小时前
【附C语言源码】C语言 栈结构 实现及其扩展操作
c语言·开发语言·数据结构·算法·链表·指针·
YuanDaima20481 小时前
图论基础原理与题目说明
数据结构·人工智能·python·算法·图论·手撕代码
z200509301 小时前
今日算法(二叉树)
数据结构
小赵不会秃头1 小时前
数据结构Day 06:线性结构、库操作及 Makefile 完整学习笔记
java·linux·数据结构·算法·面试
郝学胜-神的一滴2 小时前
干货版《算法导论》04:渐近复杂度与序列接口实战
java·开发语言·数据结构·c++·python·算法
curry____3032 小时前
二叉树的前序中序遍历以及用前序和中序求解树
数据结构
洛水水2 小时前
【力扣100题】47.最长递增子序列
算法·leetcode·职场和发展
科技快报2 小时前
腾讯地图上线骑手模式 助力解决骑手配送“最后100米”难题
数据结构
木子墨5162 小时前
系统设计面试 | 实现一个限流器:滑动窗口 → 令牌桶 → 漏桶
java·开发语言·数据结构·数据库·面试·职场和发展