题解 | #求二叉树的层序遍历-两种方法#

求二叉树的层序遍历

http://www.nowcoder.com/practice/04a5560e43e24e9db4595865dc9c63a3

记录下层次

function levelOrder( root ) {
    // write code here
    let res = [];
    if(!root) return res;
    let q = [[root,0]];
    while(q.length){
        let [n,l] = q.shift();
        if(!res[l]){ res.push([n.val])}
        else{res[l].push(n.val)};
        if(n.left) q.push([n.left,l+1]);
        if(n.right) q.push([n.right,l+1]);
    }
    return res;
}

队列中只有某一层节点

function levelOrder( root ) {
    // write code here
    let res = [];
    if(!root) return res;
    let q = [root];
    while(q.length){
        let len = q.length;
//         这里先推入一个空数组
        res.push([]);
        while(len --){
            const head = q.shift();
//             收集结果
            res[res.length - 1].push(head.val);
//             将左右进栈--第二层的
            if(head.left) q.push(head.left);
            if(head.right) q.push(head.right);
        }
    }
    //console.log(res);
    return res;
}
全部评论

相关推荐

02-22 18:38
门头沟学院 Java
程序员牛肉:标准的NPC简历,一个短链接+12306。你可以在牛客上面搜一搜有多少人的简历和你一样。你自己能不能给出你一个理由让面试官在大家简历高度相同的情况下,选择约面你而不是对应的211,985学生? 是因为你即将拥有的那段小厂实习吗?这种小厂实习真的很有含金量吗?因此你可以找实习,但是你如果只能找到小厂实习的话,其实意义不太大。 但你的时间是充足的,相信我:从现在到今年的九月份大三上你就干两个事情:"写博客"+“参加开源之夏”。这两个搞好了不亚于一段大厂实习的含金量。 想要让自己变得更强,首先就是不要把自己当打工人看待,让自己简历上面的活人气息更多一点,不要让自己成为流水线的产物。你不是在出售你的技能,你是在利用你的技能和公司达成一种合作关系。
点赞 评论 收藏
分享
zhiyog:666,你看郑州有几个互联网公司?,农业大省zf哪来资金投入互联网。。。(河南人吐槽)****海投大城市,面试会有的
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客企业服务