1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32
| /** * Definition for a binary tree node. * type TreeNode struct { * Val int * Left *TreeNode * Right *TreeNode * } */ func zigzagLevelOrder(root *TreeNode) [][]int { ans := [][]int{} var dfs func(node *TreeNode, depth int) dfs = func(node *TreeNode, depth int) { if node == nil { return } if len(ans) <= depth { ans = append(ans, []int{}) } if (depth & 1) == 0 { ans[depth] = append(ans[depth], node.Val) } else { // 往切片的头部插入一个元素 ans[depth] = append(ans[depth], -1) copy(ans[depth][1:], ans[depth]) ans[depth][0] = node.Val } dfs(node.Left, depth+1) dfs(node.Right, depth+1) } dfs(root, 0) return ans }
|