题解 | #从上往下打印二叉树#

从上往下打印二叉树

https://www.nowcoder.com/practice/7fe2212963db4790b57431d9ed259701

# class TreeNode:
#     def __init__(self, x):
#         self.val = x
#         self.left = None
#         self.right = None
#
# 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可
#
# 
# @param root TreeNode类 
# @return int整型一维数组
#
class Solution:
    def PrintFromTopToBottom(self , root: TreeNode) -> List[int]:
        # write code here
        res = []
        queue = []
        queue.append(root)

        while (queue):
            nroot = queue.pop(0)
            if nroot:
                res.append(nroot.val)
                queue.append(nroot.left)
                queue.append(nroot.right)

        return res

queue: 保存当前根节点,以while遍历所有节点。

nroot:queue的第一个节点,以在if中逐个处理所有子节点。

ref:

https://blog.csdn.net/gg864461719/article/details/122470976

全部评论

相关推荐

点赞 收藏 评论
分享
牛客网
牛客企业服务