每日一题---剑指 Offer 32 - III. 从上到下打印二叉树 III[力扣][Go]

简介: 每日一题---剑指 Offer 32 - III. 从上到下打印二叉树 III[力扣][Go]

题目描述

请实现一个函数按照之字形顺序打印二叉树,即第一行按照从左到右的顺序打印,第二层按照从右到左的顺序打印,第三行再按照从左到右的顺序打印,其他行以此类推。

解题代码

// 利用顺序表做,不递归
func levelOrder(root *TreeNode) [][]int {
  var sum [][]int
  var tem []int
  n := 1
  var queue []*TreeNode
  if root != nil {
    queue = append(queue, root)
  }
  for len(queue) != 0 {
    if n%2 == 0{
      for size := len(queue) - 1; size >= 0; size-- {
        node := queue[size]
        tem = append(tem, node.Val)
        if node.Right != nil {
          queue = append(queue, node.Right)
        }
        if node.Left != nil {
          queue = append(queue, node.Left)
        }
        if size == 0{
          queue = queue[1:]
        } else {
          tem2 := queue[size+1:]
          queue = queue[:size]
          for _, treeNode := range tem2 {
            queue = append(queue,treeNode)
          }
        }
      }
    } else {
      for size := len(queue) - 1; size >= 0; size-- {
        node := queue[size]
        tem = append(tem, node.Val)
        if node.Left != nil {
          queue = append(queue, node.Left)
        }
        if node.Right != nil {
          queue = append(queue, node.Right)
        }
        if size == 0{
          queue = queue[1:]
        } else {
          tem2 := queue[size+1:]
          queue = queue[:size]
          for _, treeNode := range tem2 {
            queue = append(queue,treeNode)
          }
        }
      }
    }
    sum = append(sum, tem)
    tem = []int{}
    n++
  }
  return sum
}

也可以利用链表进行前插和后插的交替来模拟队列完成,我懒就不写了。

提交结果


相关文章
|
3月前
【LeetCode 31】104.二叉树的最大深度
【LeetCode 31】104.二叉树的最大深度
30 2
|
3月前
【LeetCode 29】226.反转二叉树
【LeetCode 29】226.反转二叉树
26 2
|
3月前
【LeetCode 28】102.二叉树的层序遍历
【LeetCode 28】102.二叉树的层序遍历
21 2
|
3月前
【LeetCode 43】236.二叉树的最近公共祖先
【LeetCode 43】236.二叉树的最近公共祖先
24 0
|
3月前
【LeetCode 38】617.合并二叉树
【LeetCode 38】617.合并二叉树
21 0
|
3月前
【LeetCode 37】106.从中序与后序遍历构造二叉树
【LeetCode 37】106.从中序与后序遍历构造二叉树
27 0
|
3月前
【LeetCode 34】257.二叉树的所有路径
【LeetCode 34】257.二叉树的所有路径
25 0
|
3月前
【LeetCode 32】111.二叉树的最小深度
【LeetCode 32】111.二叉树的最小深度
21 0
|
5月前
|
存储 算法
二叉树进阶-学会层序遍历助你一次刷完leetcode10道题
文章深入探讨了二叉树的层序遍历方法,并展示了如何通过队列实现层序遍历的算法逻辑,同时指出掌握层序遍历技巧可以帮助解决LeetCode上的多道相关题目。
二叉树进阶-学会层序遍历助你一次刷完leetcode10道题
|
5月前
|
算法 Java
LeetCode第94题二叉树的中序遍历
文章介绍了LeetCode第94题"二叉树的中序遍历"的解法,使用递归实现了中序遍历的过程,遵循了"左根右"的遍历顺序,并提供了清晰的Java代码实现。
LeetCode第94题二叉树的中序遍历