leetcode 热题100刷题-二叉树的中序遍历

题号:94

题目:二叉树的中序遍历

难度:简单

链接:https://leetcode.cn/problems/binary-tree-inorder-traversal/

2022/08/23答案

算法思路

  本题在课程中是学过的。

  大致的思路就是利用迭代。首先是前序、中序、后序的遍历的意思,可以直接通过前/中/后这三个字来理解。前就是第一个遍历根节点(根节点->左子树->右子树),中就是第二个遍历根节点(左子树->根节点->右子树),后就是最后再遍历根节点(左子树->右子树->根节点)。

  那样的话,可以通过递归的思想来实现。

  当然因为递归对我来说真的是只可意会不可言传(我真的不是特别的能理解递归)。

代码

class Solution:

    def inorderTraversal(self, root: Optional[TreeNode]) -> List[int]:
        """
        查看数据
        TreeNode{val: 1, left: None, right: TreeNode{val: 2, left: TreeNode{val: 3, left: None, right: None}, right: None}}
        """
        if root == None:
            return []
        li_out = []
        li_out = self.inorderTraversal(root.left)

        li_out.append(root.val)

        li_out.extend(self.inorderTraversal(root.right))

        return li_out

结果

  

思考

  让我自己写递归的话,我肯定是不行的。但进阶版貌似是利用迭代?稍后会再行思考。

posted @ 2022-08-24 07:55  小澳子  阅读(44)  评论(0编辑  收藏  举报