145. 二叉树的前序遍历

二叉树的前序遍历

解法一: 递归

go
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
/**
* Definition for a binary tree node.
* type TreeNode struct {
* Val int
* Left *TreeNode
* Right *TreeNode
* }
*/
func preorderTraversal(root *TreeNode) []int {
ans := []int{}
var dfs func(node *TreeNode)
dfs = func(node *TreeNode) {
if node == nil {
return
}
ans = append(ans, node.Val)
dfs(node.Left)
dfs(node.Right)
}
dfs(root)
return ans
}

解法二: Morris 遍历

go
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 preorderTraversal(root *TreeNode) []int {
ans := []int{}
node := root
for node != nil {
if node.Left != nil {
postNode := node.Left
for postNode.Right != nil && postNode.Right != node {
postNode = postNode.Right
}
if postNode.Right == nil {
ans = append(ans, node.Val)
postNode.Right = node
node = node.Left
} else {
node = node.Right
postNode.Right = nil
}
} else {
ans = append(ans, node.Val)
node = node.Right
}
}
return ans
}
作者

wuhunyu

发布于

2024-02-11

更新于

2025-01-15

许可协议