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

方法一:广度优先搜索

时间复杂度:O(n)

空间复杂度:O(n)

复制代码
 1 /**
 2  * Definition for a binary tree node.
 3  * function TreeNode(val, left, right) {
 4  *     this.val = (val===undefined ? 0 : val)
 5  *     this.left = (left===undefined ? null : left)
 6  *     this.right = (right===undefined ? null : right)
 7  * }
 8  */
 9 /**
10  * @param {TreeNode} root
11  * @return {number[][]}
12  */
13 var levelOrder = function(root) {
14     const ret=[];
15     if(!root){
16         return ret;
17     }
18     const q=[];
19     q.push(root);
20     while(q.length!==0){
21         const currentLevelSize = q.length;
22         ret.push([]);
23         for(let i=1;i<=currentLevelSize;++i){
24             const node = q.shift();
25             ret[ret.length-1].push(node.val);
26             if(node.left) q.push(node.left);
27             if(node.right) q.push(node.right);
28         }
29     }
30     return ret
31 
32 };
复制代码

 

posted @   icyyyy  阅读(23)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· 终于写完轮子一部分:tcp代理 了,记录一下
· 震惊!C++程序真的从main开始吗?99%的程序员都答错了
· 别再用vector<bool>了!Google高级工程师:这可能是STL最大的设计失误
· 单元测试从入门到精通
· 【硬核科普】Trae如何「偷看」你的代码?零基础破解AI编程运行原理
点击右上角即可分享
微信分享提示