zoukankan      html  css  js  c++  java
  • 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
     
     
  • 相关阅读:
    #writeup#pwnable unlink
    #pwnable#cmd2
    #writeup# 深交所CTF内训T2-上传漏洞
    #writeup# 深交所CTF内训T1-SQL注入
    HAProxy 基本翻译
    概况
    Day 2 @ RSA Conference Asia Pacific & Japan 2016
    Burp suite安装使用教程
    Windows server 2012 iis 网页HTTP 404.17
    SQL Server、MySQL、Oracle查询前n条记录
  • 原文地址:https://www.cnblogs.com/ChevisZhang/p/12456895.html
Copyright © 2011-2022 走看看