2019-05-03 13:10:40 +08:00
|
|
|
package binarytree
|
|
|
|
|
|
|
|
type TreeNode struct {
|
|
|
|
Val int
|
|
|
|
Left *TreeNode
|
|
|
|
Right *TreeNode
|
|
|
|
}
|
|
|
|
|
|
|
|
func preOrderTraversal(root *TreeNode) []int {
|
|
|
|
if root == nil {
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
if root.Left == nil && root.Right == nil {
|
|
|
|
return []int{root.Val}
|
|
|
|
}
|
|
|
|
var stack []*TreeNode
|
|
|
|
var res []int
|
|
|
|
stack = append(stack, root)
|
|
|
|
for len(stack) != 0 {
|
|
|
|
e := stack[len(stack)-1]
|
|
|
|
stack = stack[:len(stack)-1]
|
|
|
|
res = append(res, e.Val)
|
|
|
|
if e.Right != nil {
|
|
|
|
stack = append(stack, e.Right)
|
|
|
|
}
|
|
|
|
if e.Left != nil {
|
|
|
|
stack = append(stack, e.Left)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return res
|
|
|
|
}
|
|
|
|
|
|
|
|
func inOrderTraversal(root *TreeNode) []int {
|
|
|
|
if root == nil {
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
if root.Left == nil && root.Right == nil {
|
|
|
|
return []int{root.Val}
|
|
|
|
}
|
|
|
|
res := inOrderTraversal(root.Left)
|
|
|
|
res = append(res, root.Val)
|
|
|
|
res = append(res, inOrderTraversal(root.Right)...)
|
|
|
|
|
|
|
|
return res
|
|
|
|
}
|
|
|
|
|
|
|
|
func postOrderTraversal(root *TreeNode) []int {
|
|
|
|
if root == nil {
|
|
|
|
return nil
|
|
|
|
}
|
2019-05-03 13:16:52 +08:00
|
|
|
var res []int
|
|
|
|
if root.Left != nil {
|
|
|
|
lres := postOrderTraversal(root.Left)
|
|
|
|
if len(lres) > 0 {
|
|
|
|
res = append(res, lres...)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
if root.Right != nil {
|
|
|
|
rres := postOrderTraversal(root.Right)
|
|
|
|
if len(rres) > 0 {
|
|
|
|
res = append(res, rres...)
|
|
|
|
}
|
2019-05-03 13:10:40 +08:00
|
|
|
}
|
|
|
|
res = append(res, root.Val)
|
|
|
|
return res
|
|
|
|
}
|