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

Posted 福大大架构师每日一题

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了2021-10-06:二叉树的锯齿形层序遍历。给定一个二叉树,返回其节点值的锯齿形层序遍历。(即先从左往右,再从右往左进行下一层遍历,以此类推,层与层之间交替进行)。力扣103。相关的知识,希望对你有一定的参考价值。

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

福大大 答案2021-10-06:

自然智慧即可。层次遍历。
时间复杂度:O(N)。
空间复杂度:O(N)。

代码用golang编写。代码如下:

package main

import "fmt"

func main() {
    head := &TreeNode{}
    head.val = 3

    head.left = &TreeNode{}
    head.left.val = 9
    head.right = &TreeNode{}
    head.right.val = 20

    head.right.left = &TreeNode{}
    head.right.left.val = 15
    head.right.right = &TreeNode{}
    head.right.right.val = 7

    ret := zigzagLevelOrder(head)
    fmt.Println(ret)
}

type TreeNode struct {
    val   int
    left  *TreeNode
    right *TreeNode
}

func zigzagLevelOrder(root *TreeNode) [][]int {
    ans := make([][]int, 0)
    if root == nil {
        return ans
    }
    deque := make([]*TreeNode, 0)
    deque = append(deque, root)
    size := 0
    isHead := true
    for len(deque) > 0 {
        size = len(deque)
        curLevel := make([]int, 0)
        for i := 0; i < size; i++ {
            var cur *TreeNode
            if isHead {
                cur = deque[0]
                deque = deque[1:]
            } else {
                cur = deque[len(deque)-1]
                deque = deque[0 : len(deque)-1]
            }
            curLevel = append(curLevel, cur.val)
            if isHead {
                if cur.left != nil {
                    deque = append(deque, cur.left)
                }
                if cur.right != nil {
                    deque = append(deque, cur.right)
                }
            } else {
                if cur.right != nil {
                    deque = append([]*TreeNode{cur.right}, deque...)
                }
                if cur.left != nil {
                    deque = append([]*TreeNode{cur.left}, deque...)
                }
            }
        }
        ans = append(ans, curLevel)
        isHead = !isHead
    }
    return ans
}

执行结果如下:


左神java代码

以上是关于2021-10-06:二叉树的锯齿形层序遍历。给定一个二叉树,返回其节点值的锯齿形层序遍历。(即先从左往右,再从右往左进行下一层遍历,以此类推,层与层之间交替进行)。力扣103。的主要内容,如果未能解决你的问题,请参考以下文章

Leetcode No.103 二叉树的锯齿形层序遍历

leetcode103二叉树的锯齿形层序遍历

LeetCode-103-二叉树的锯齿形层序遍历

算法打卡二叉树的锯齿形层序遍历

算法刷题-二叉树的锯齿形层序遍历用栈实现队列_栈设计买卖股票的最佳时机 IV

LeetCode第103题—二叉树的锯齿形层序遍历—Python实现