Python实现BST
二叉排序树(BST)又称二叉查找树、二叉搜索树
二叉排序树(Binary Sort Tree)又称二叉查找树。它或者是一棵空树;或者是具有下列性质的二叉树:
1.若左子树不空,则左子树上所有结点的值均小于根结点的值;
2.若右子树不空,则右子树上所有结点的值均大于根节点的值;
3.左、右子树也分别为二叉排序树。
- 求树深度
- 按序输出节点值(使用中序遍历)
- 查询二叉搜索树中一个具有给点关键字的结点,返回该节点的位置。时间复杂度是O(h),h是树的高度。
- 递归/迭代求最大关键字元素
- 递归/迭代求最小关键字元素
# -*- coding:utf-8 -*-
'''
用Python实现二叉搜索树。
'''
class Node():
def __init__(self, x):
self.val = x
self.left = None
self.right = None
#求树的深度
def depth(root):
if root is