[Python]二叉树中序遍历代码以及思路

思路:

把中序遍历分为一个有三个阶段的循环,左子节点入栈,没有右子节点出栈,
有右子节点则出栈并且右子节点入栈。

代码:

二叉树节点定义如下

class TreeNode:
    def __init__(self, val=0, left=None, right=None):
        self.val = val
        self.left = left
        self.right = right
class Solution:
    def inorderTraversal(self, root: Optional[TreeNode]) -> List[int]:
        ans=[]
        if(root==None):
            return []
        
        st=[root]
        while(st):
            root=st[-1]      
            while(root.left!=None):
                st.append(root.left)
                root=root.left
            while(st and st[-1].right==None):
                ans=ans+[st.pop().val]
            if(st):
                right_node=st.pop()
                ans=ans+[right_node.val]
                st.append(right_node.right)

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值