数据结构 18 【复习】广义表 | 各种内部排序 | 二叉排序树的平均查找长度 ASL

1 广义表

定义

题目

2 各种内部排序

排序算法的一般选择规则

内部排序的分类

1. 插入类排序 (Insertion Sorts)

这类排序的思想是将一个待排序的记录按其关键字的大小插入到前面已经排好序的子序列中 。

  • 直接插入排序:在序列"基本有序"或数据量较小时效率极高 。

  • 希尔排序 (Shell Sort):也称"缩小增量排序",是插入排序的一种更高效的改进版本。

2. 交换类排序 (Exchange Sorts)

通过比较两个记录的关键字,如果不满足次序要求(如逆序)则进行交换。

  • 冒泡排序 (Bubble Sort):最基础的交换排序。

  • 快速排序 (Quick Sort):采用分治法。虽然在某些情况下(如初始序列基本有序)不是最快的,但在平均性能上非常优越 。

3. 选择类排序 (Selection Sorts)

每一趟从待排序的记录中选出关键字最小(或最大)的记录,放置在已排序序列的最后 。

  • 简单选择排序:从头到尾扫描选最小项 。

  • 堆排序 (Heap Sort) :利用大顶堆或小顶堆结构进行筛选 。

  • 稳定性 :选择类排序通常是不稳定的 。

4. 归并类排序 (Merging Sorts)

将两个或两个以上的有序表组合成一个新的有序表 。

  • 二路归并排序:将序列不断二分,再两两合并。

5. 分配类排序 (Distribution Sorts)

不通过直接的关键字比较,而是根据关键字的位(如个位、十位)进行分配和收集。

  • 基数排序 (Radix Sort):按照位值的顺序(如从低位到高位)进行多轮排序。
排序类别 典型算法 稳定性 备注
插入类 直接插入、希尔 稳定 序列基本有序时表现优秀
交换类 快排、冒泡 不稳定 平均时间复杂度 O (n log2 n)
选择类 简单选择排序、堆排序 不稳定 空间复杂度低,适合海量数据
归并类 归并排序 稳定 时间复杂度始终为 O (n log2 n)
分配类 基数排序 稳定 适用于关键字位数较少的情况

3 二叉排序树的平均查找长度 ASL

二叉排序树(BST)的查找效率(平均查找长度 ASL)直接取决于树的高度。对于具有 N 个结点的二叉排序树:

  1. 最好情况(平衡状态):当二叉排序树接近完全二叉树或经过平衡处理(如 AVL 树)时,其高度约为 log2 N 的下取整加 1。在这种情况下,查找长度与 O (log2 N) 同阶,查找效率最高。

  2. 最坏情况(退化状态):如果插入的关键字序列是有序的(例如 1, 2, 3, 4, 5),构造出的二叉排序树会退化为一棵单支树(类似于一个线性链表)。此时,树的高度变为 N,查找长度也随之退化为 O (N),效率最低。

相关推荐
铁蛋AI编程实战8 分钟前
最新 豆包4.0 实操手册:混合架构部署 + 实时交互 + 动态学习
学习·架构·交互
Titan202411 分钟前
搜索二叉树笔记模拟实现
数据结构·c++·笔记·学习
野木香25 分钟前
solidity学习
学习
不染尘.25 分钟前
二叉树相关题目
开发语言·数据结构·c++·算法
Lester_110139 分钟前
嵌入式学习笔记 - 自举电路
笔记·嵌入式硬件·学习
Imxyk39 分钟前
力扣:632. 最小区间(贪心)
java·数据结构·算法
驱动探索者41 分钟前
linux genpool 学习
java·linux·学习
yukai0800844 分钟前
【最后203篇系列】036 MDP学习思考
人工智能·学习
历程里程碑1 小时前
21:重谈重定义理解一切皆“文件“及缓存区
linux·c语言·开发语言·数据结构·c++·算法·缓存
2501_901147831 小时前
PyTorch DDP官方文档学习笔记(核心干货版)
pytorch·笔记·学习·算法·面试