题解 | #按之字形顺序打印二叉树#

按之字形顺序打印二叉树

https://www.nowcoder.com/practice/91b69814117f4e8097390d107d2efbe0

/*class TreeNode {
 *     val: number
 *     left: TreeNode | null
 *     right: TreeNode | null
 *     constructor(val?: number, left?: TreeNode | null, right?: TreeNode | null) {
 *         this.val = (val===undefined ? 0 : val)
 *         this.left = (left===undefined ? null : left)
 *         this.right = (right===undefined ? null : right)
 *     }
 * }
 */

/**
 * 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可
 * 
 * @param pRoot TreeNode类 
 * @return int整型二维数组
 */
export function Print(pRoot: TreeNode): number[][] {
    // write code here
    if (pRoot === null) return []
    let l2r = true
    const result = []
    const cache: TreeNode[][] = [[pRoot]]
    while (cache.length > 0) {
        const headCache = cache.shift()
        const headCopy = [...headCache]
        if (!l2r) {
            headCache.reverse()
            l2r = true
        } else {
            l2r = false
        }
        result.push(headCache.map(({ val }) => val))
        const current = []
        for (let i = 0; i < headCopy.length; i++) {
            if (headCopy[i].left) {
                current.push(headCopy[i].left)
            }
            if (headCopy[i].right) {
                current.push(headCopy[i].right)
            }
        }
        if (current.length > 0) {
            cache.push(current)
        }
    }
    return result
}

全部评论

相关推荐

和蔼:在竞争中脱颖而出,厉害! 但是有一个小问题:谁问你了?😡我的意思是,谁在意?我告诉你,根本没人问你,在我们之中0人问了你,我把所有问你的人都请来 party 了,到场人数是0个人,誰问你了?WHO ASKED?谁问汝矣?誰があなたに聞きましたか?누가 물어봤어?我爬上了珠穆朗玛峰也没找到谁问你了,我刚刚潜入了世界上最大的射电望远镜也没开到那个问你的人的盒,在找到谁问你之前我连癌症的解药都发明了出来,我开了最大距离渲染也没找到谁问你了我活在这个被辐射蹂躏了多年的破碎世界的坟墓里目睹全球核战争把人类文明毁灭也没见到谁问你了
点赞 评论 收藏
分享
挣K存W养DOG:他真的很中意你,为什么不回他
点赞 评论 收藏
分享
点赞 收藏 评论
分享
牛客网
牛客企业服务