• 103. 二叉树的锯齿形层次遍历-树(leetcode)


    给定一个二叉树,返回其节点值的锯齿形层次遍历。(即先从左往右,再从右往左进行下一层遍历,以此类推,层与层之间交替进行)。

    原思路(错误的):

      *)忽略了DFS只能决定 当前节点下一层的遍历顺序, 不能决定本层的所有节点遍历顺序,所以需要用到双向列表的数据结构。

      from collections import deque

      a)用DFS + level 的方法进行BFS遍历

      b)通过 level%2 == 0 来判断应该 helper(node.left,level)  和  helper(node.right,level) 两个谁先

    更正:

      *)本题保存了,作为树的练习,以后多刷几次。

    from collections import deque
    class Solution:
        def zigzagLevelOrder(self, root: TreeNode) -> List[List[int]]:
            res = [] 
            def helper(node,level):
                if not node:
                    return
                if level == len(res):
                    res.append(deque([]))
                if level%2 == 1:
                    res[level].appendleft(node.val)
                elif level%2 == 0:
                    res[level].append(node.val)
                helper(node.left,level+1)
                helper(node.right,level+1)
            helper(root,0)
            new_res = []
            for list_ in res:
                new_res.append([val for val in list_])
            return new_res
     
     
  • 相关阅读:
    idea--不能启动问题
    linux--mysql5.7安装
    vmware
    debezium
    java枚举
    springfox
    日志级别
    lombok--知识点
    es6--箭头函数
    网址访问过慢
  • 原文地址:https://www.cnblogs.com/ChevisZhang/p/12456895.html
Copyright © 2020-2023  润新知