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

按之字形顺序打印二叉树

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

参考了评论区大佬思路:
1.通过while语句遍历树
2.使用enumerate 实现之字形打印

# -*- coding:utf-8 -*-
# class TreeNode:
#     def __init__(self, x):
#         self.val = x
#         self.left = None
#         self.right = None
class Solution:
    def Print(self, pRoot):
        # write code here
        ##首先判断是否存在根节点
        if not pRoot:
            return []
        nodestack = [pRoot]
        result = []
        while nodestack:
            res = []
            nextstack = []
            for i in nodestack:
                res.append(i.val)
                if i.left:
                    nextstack.append(i.left)
                if i.right:
                    nextstack.append(i.right)
            nodestack = nextstack
            result.append(res)
        returnRes = []
        for idx,v in enumerate(result):
            if idx%2==0:
                returnRes.append(v)
            else:
                returnRes.append(v[::-1])
        return returnRes
全部评论
我也是这样的思路,先层序遍历拿出来每层的值,然后在翻转
点赞 回复 分享
发布于 2022-03-23 17:17

相关推荐

12-27 22:21
门头沟学院 Java
点赞 评论 收藏
分享
面了100年面试不知...:今年白菜这么多,冬天可以狂吃了
点赞 评论 收藏
分享
11-03 14:57
西北大学 营销
Belltrix:其实就是每根转动一定的角度
点赞 评论 收藏
分享
评论
4
收藏
分享

创作者周榜

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