文章目录
1. 用于查找的树
1.1 二叉排序树SBT
1.1.1 定义
二叉排序树(Binary Sort Tree),又称二叉查找树(Binary Search Tree),亦称二叉搜索树。
二叉排序树或者是一棵空树,或者是具有下列性质的二叉树:
(1)若左子树不空,则左子树上所有结点的值均小于它的根结点的值;
(2)若右子树不空,则右子树上所有结点的值均大于它的根结点的值;
(3)左、右子树也分别为二叉排序树;
(4)没有键值相等的节点。
1.1.2 查找插入和删除操作
- 查找:若根结点的关键字值等于查找的关键字,成功。否则,若小于根结点的关键字值,递归查左子树。若大于根结点的关键字值,递归查右子树。若子树为空,查找不成功。平均时间复杂度P(n)=O(logn)
- 插入:每次插入的新节点都是二叉排序树上新的叶子节点,不必移动其他节点,仅需要改动某个节点的指针,由空变成非空。
- 删除:比较复杂,分3种情况。
1.1.3 为什么叫二叉排序树?
因为中序遍历二叉排序树可得到一个关键字的有序序列。一个无序序列可以通过构造一颗二叉排序树而变成一个有序序列,构造树的过程就是对无序序列进行排序的过程。