32扩展. 把二叉树打印成n行

把二叉树打印成多行

http://www.nowcoder.com/questionTerminal/445c44d982d04483b04a54f298796288

  • tobeprint记录该层节点还有多少要打印的,当tobeprint == 0 时,该层打印完毕
# -*- coding:utf-8 -*-
# class TreeNode:
#     def __init__(self, x):
#         self.val = x
#         self.left = None
#         self.right = None
class Solution:
    # 返回二维列表[[1,2],[4,5]]
    def Print(self, pRoot):
        # write code here
        if not pRoot:return ''
        queue = [pRoot]
        helper = []
        tobeprint = 1
        nextlevel = 0
        res = []
        while queue:
            if queue[0].left:
                queue.append(queue[0].left)
                nextlevel += 1
            if queue[0].right:
                queue.append(queue[0].right)
                nextlevel += 1
            tobeprint -= 1
            helper.append(queue[0].val)
            queue.pop(0)
            if tobeprint == 0:
                res.append(helper)
                helper = []
                tobeprint = nextlevel
                nextlevel = 0
        return res
全部评论

相关推荐

Edgestr:没项目地址就干脆把那一栏删了呗
点赞 评论 收藏
分享
不会做题的小熊:我感觉我就算是找不到工作,我也不会作弊进去,作弊进去感觉一方面是自己不踏实,其次就是都靠作弊了,那后面肯定工作的心态是不一样的,没有一种内驱力。
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务