【学习记录】二叉树递归前中后序遍历

最近终于系统学一遍二叉树遍历,回顾笔记

递归定义

递归三要素

  1. 确定递归函数的参数和返回值

  2. 确定终止条件

  3. 确定单层递归的逻辑

代码

前序遍历

# Definition for a binary tree node.
class TreeNode(object):
    def __init__(self, val=0, left=None, right=None):
        self.val = val
        self.left = left
        self.right = right
class Solution(object):
    def preorderTraversal(self, root):
        """
        :type root: TreeNode
        :rtype: List[int]
        """
        res = []
    
        def loop_traversals(root):
            if root == None:
                return
            res.append(root.val)
            loop_traversals(root.left)
            loop_traversals(root.right)

        loop_traversals(root)
        return res 


        
    def preorderTraversal_leetcode(self,root):
        if not root:return []
        ans,stack = [],[root]
        while stack:
            curr = stack.pop()
            ans.append(curr.val)

            if curr.right:
                stack.append(curr.right)
            if curr.left:
                stack.append(curr.left)

        return ans

中序遍历

# Definition for a binary tree node.
class TreeNode(object):
    def __init__(self, val=0, left=None, right=None):
        self.val = val
        self.left = left
        self.right = right
class Solution(object):
    def inorderTraversal(self, root):
        """
        :type root: TreeNode
        :rtype: List[int]
        """
        res = [] 

        def loop_traversals(root):
            if root == None:
                return 

            loop_traversals(root.left)
            res.append(root.val)
            loop_traversals(root.right)
        loop_traversals(root)
        return res 

后序遍历

# Definition for a binary tree node.
class TreeNode(object):
    def __init__(self, val=0, left=None, right=None):
        self.val = val
        self.left = left
        self.right = right
class Solution(object):
    def postorderTraversal(self, root):
        """
        :type root: TreeNode
        :rtype: List[int]
        """
        res =[]
        def loop(root):
            if root == None:return 
            loop(root.left)
            loop(root.right)
            res.append(root.val)
        loop(root)
        return res 
        ```

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值