如何使用python实现二叉排序树(python,开发技术)

时间:2024-05-05 00:55:39 作者 : 石家庄SEO 分类 : 开发技术
  • TAG :

方法一(粗暴)

#二叉排序树classBTree():def__init__(self,data):self.left=Noneself.right=Noneiftype(data)==list:self.data=data[0]fordindata[1:]:self.insert(d)else:self.data=datadefinsert(self,data):bt=selfwhileTrue:ifdata<=bt.data:ifbt.left==None:bt.left=BTree(data)breakelse:bt=bt.leftelse:ifbt.right==None:bt.right=BTree(data)breakelse:bt=bt.rightdefmid_order(self):res=[]stack=[]node=selfwhilenodeorstack:whilenode:stack.append(node)node=node.leftnode=stack.pop()res.append(node.data)node=node.rightreturnresdata=[5,1,2,3,6,8,9]bt=BTree(data)print(bt.mid_order())

如何使用python实现二叉排序树

方法二(递归)

classTreeNode(object):def__init__(self,data):self.data=dataself.left=Noneself.right=NoneclassBinaryTree(object):definsert(self,root,node):ifrootisNone:returnnodeifnode.data<root.data:root.left=self.insert(root.left,node)else:root.right=self.insert(root.right,node)returnrootdefmid_order(self,root):node=rootstack=[]res=[]whilenodeorstack:whilenode:stack.append(node)node=node.leftnode=stack.pop()res.append(node.data)node=node.rightreturnresdata=[5,1,2,3,6,8,9]root=TreeNode(data[0])tree=BinaryTree()foriindata[1:]:tree.insert(root,TreeNode(i))print(tree.mid_order(root))

如何使用python实现二叉排序树

 </div> <div class="zixun-tj-product adv-bottom"></div> </div> </div> <div class="prve-next-news">
本文:如何使用python实现二叉排序树的详细内容,希望对您有所帮助,信息来源于网络。
上一篇:如何使用css实现垂直导航栏和水平导航栏下一篇:

8 人围观 / 0 条评论 ↓快速评论↓

(必须)

(必须,保密)

阿狸1 阿狸2 阿狸3 阿狸4 阿狸5 阿狸6 阿狸7 阿狸8 阿狸9 阿狸10 阿狸11 阿狸12 阿狸13 阿狸14 阿狸15 阿狸16 阿狸17 阿狸18