题解 | #二叉树的前序遍历#

二叉树的前序遍历

http://www.nowcoder.com/practice/5e2135f4d2b14eb8a5b06fab4c938635

二叉树的前序遍历

题目描述 给你二叉树的根节点 root ,返回它节点值的 前序 遍历。

方法一:python方法

解题思路

对于本题,前序遍历就是一个递归,直接套模板,使用python实现。

alt

解题代码

class Solution:
    def preorderTraversal(self , root: TreeNode) -> List[int]:
        # write code here
        result = []
        def preorder(root):
            if not root:
                return
            result.append(root.val)
            preorder(root.left)
            preorder(root.right)
        preorder(root)
        return result

复杂度分析

时间复杂度:使用递归,因此时间复杂度为O(n)O(n)

空间复杂度:使用递归,递归栈使用内存地址空间,因此空间复杂度为O(n)O(n)

方法二:golang方法

解题思路

思路同方法一,使用golang实现。

解题代码

package main
import . "nc_tools"

func preorderTraversal( root *TreeNode ) []int {
    // write code here
    res:=make([]int,0)
    preOrder(&res,root)
    return res
}
func preOrder(res *[]int,root *TreeNode){
    if root==nil{
        return
    }
    *res=append(*res, root.Val)
    preOrder(res,root.Left)
    preOrder(res,root.Right)
}

复杂度分析

时间复杂度:使用递归,因此时间复杂度为O(n)O(n)

空间复杂度:使用递归,递归栈使用内存地址空间,因此空间复杂度为O(n)O(n)

算法 文章被收录于专栏

算法题的题解以及感受

全部评论
请问go的切片不是地址传递吗?为什么这里不用指针会错
点赞 回复 分享
发布于 2022-03-26 10:19

相关推荐

投票
我要狠拿offer:如果不是必须去成都绝对选九院呀,九院在四川top1研究所了吧
点赞 评论 收藏
分享
11-05 07:29
贵州大学 Java
点赞 评论 收藏
分享
点赞 收藏 评论
分享
牛客网
牛客企业服务