如何使用python实现二叉排序树
如何使用python实现二叉排序树
小编给大家分享一下如何使用python实现二叉排序树,希望大家阅读完这篇文章之后都有所收获,下面让我们一起去探讨吧!
方法一(粗暴)
#二叉排序树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())
方法二(递归)
classTreeNode(object):def__init__(self,data):self.data=dataself.left=Noneself.right=NoneclassBinaryTree(object):definsert(self,root,node):ifrootisNone:returnnodeifnode.data 看完了这篇文章,相信你对“如何使用python实现二叉排序树”有了一定的了解,如果想了解更多相关知识,欢迎关注恰卡编程网行业资讯频道,感谢各位的阅读!
推荐阅读
-
Python 3.12 新特性解析:模式匹配增强与性能优化实战
-
Lightly IDE 深度评测:轻量级 Python 开发工具是否适合团队协作?
-
VS Code 自定义配置:JSON 文件修改、代码片段与任务自动化脚本
-
Python 虚拟环境选择:venv、conda、poetry 的适用场景对比
-
PyCharm+GitHub Copilot:Python 开发中 AI 辅助编码的最佳实践
-
PyCharm 无法识别虚拟环境?5 步排查 Python 解释器配置问题
-
数据科学工具链:Jupyter Notebook+RStudio+Python 的协同工作流
-
Python 3.12 新特性:模式匹配增强与性能改进实战
-
Lightly IDE 适合谁?轻量级 Python 开发工具深度评测
-
Python IDE 终极对比:PyCharm vs VS Code vs Jupyter Notebook