代码随想录算法训练营|day14

本文详细介绍了二叉树的中序、前序和后序遍历,分别提供了递归和迭代两种实现方式,强调了在解决问题时多思考和提问的重要性。
摘要由CSDN通过智能技术生成

遍历方法详解

1. 递归遍历   2. 迭代遍历    3. 统一迭代

94.二叉树的中序遍历

(1)递归

func inorderTraversal(root *TreeNode) []int {
    res :=[]int{}
    inorder(root, &res)
    return res
}

func inorder(root *TreeNode, res *[]int) {
    if root == nil {
        return
    }
    inorder(root.Left, res)
    *res = append(*res, root.Val)
    inorder(root.Right, res)
}

(2)迭代

主要思路:
左子树一直压栈,直到没有子节点,记录结果,弹出,遍历右子树

func inorderTraversal(root *TreeNode) []int {
    res := []int{}
    if root == nil {
        return res
    }
    stack := []*TreeNode{}
    node := root 
    for len(stack) > 0 || node != nil {
        for node != nil {
            stack = append(stack, node)
            node = node.Left
        }
        node = stack[len(stack) - 1]
        res = append(res, node.Val)
        stack = stack[:len(stack) - 1]
        node = node.Right
    }
    return res
}

144.二叉树的前序遍历

(1)递归

func preorderTraversal(root *TreeNode) []int {
    res := []int{}
    preorder(root, &res)
    return res
}

func preorder(root *TreeNode, res *[]int) {
    if root == nil {
        return
    }
    *res = append(*res, root.Val)
    preorder(root.Left, res)
    preorder(root.Right, res)
}

(2)迭代

主要思路:
左子树压栈并记录结果,直到没有子节点,弹出,遍历右子树

func preorderTraversal(root *TreeNode) []int {
    res := []int{}
    if root == nil {
        return res
    }
    stack := []*TreeNode{}
    node := root
    for len(stack) > 0 || node != nil {
        for node != nil {
            res = append(res, node.Val)
            stack = append(stack, node)
            node = node.Left
        }
        node = stack[len(stack) - 1].Right
        stack = stack[:len(stack) - 1]
    }
    return res
}

145.二叉树的后序遍历

(1)递归

func postorderTraversal(root *TreeNode) []int {
    res := []int{}
    postorder(root, &res)
    return res
}

func postorder(root *TreeNode, res *[]int) {
    if root == nil {
        return
    }
    postorder(root.Left, res)
    postorder(root.Right, res)
   *res = append(*res, root.Val)
}

(2)迭代

主要思路:
右左子树压栈并记录结果,直到没有子节点,弹出,遍历左子树,最后反转结果

func postorderTraversal(root *TreeNode) []int {
    res := []int{}
    if root == nil {
        return res
    }
    stack := []*TreeNode{}
    node := root 
    for len(stack) > 0 || node != nil {
        for node != nil {
            res = append(res, node.Val)
            stack = append(stack, node)
            node = node.Right
        }
        node = stack[len(stack) - 1].Left
        stack = stack[:len(stack) - 1]
    }
    Reverse(res)
    return res
}

func Reverse(s interface{})  {
    sort.SliceStable(s, func(i, j int) bool {
        return true
    })
}

总结

递归和迭代都是有解题套路的!多思考问问题。

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值