python 二叉树遍历 非递归遍历

class Node(object):
def init(self,val=None,left=None,right=None):
# val为节点的值,left为左子树的根节点,right为右子树的根节点
self.val = val
self.left = left
self.right = right
class BT(object):
def init(self):
self.item = []
#先序遍历
def preorder(self,root):
stack = []
while root or stack:
while root:
self.item.append(root.val)
stack.append(root)
root = root.left
if stack:
item = stack.pop()
root = item.right
#中序遍历
def midorder(self,root):
stack = []
while root or stack:
while root:
stack.append(root)
root = root.left
if stack:
item = stack.pop()
self.item.append(item.val)
root = item.right
#后序遍历,思想就是用stack1去按照根、右、左的顺序去遍历,stack2就是按照这个顺序去打印,stack2打印的顺序刚好时右序遍历的倒序
def postorder(self,root):
stack1 = []
# 后序的倒序,后 右 左
stack2 = []
while root or stack1:
while root:
stack2.append(root.val)
stack1.append(root)
root = root.right
item = stack1.pop()
root = item.left
self.item = [stack2[-i] for i in range(1,len(stack2)+1)]

bt = Node(‘D’,left=Node(‘A’,left=Node(‘F’),right=Node(‘G’,right=Node(‘E’))),right=Node(‘C’,left=Node(‘K’),right=Node(‘M’,left=Node(‘S’))))
tree1 = BT()
tree1.preorder(bt)
print(tree1.item)
tree1.midorder(bt)
print(tree1.item)
tree1.postorder(bt)
print(tree1.item)

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

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值