数据结构 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),效率最低。

相关推荐
世人万千丶1 小时前
鸿蒙跨端框架Flutter学习day 2、常用UI组件-层叠布局 Stack & Positioned
学习·flutter·ui·实时互动·harmonyos·鸿蒙
好奇龙猫1 小时前
【人工智能学习-AI入试相关题目练习-第四次】
人工智能·学习
马克学长1 小时前
SSM学生出国境学习交流管理87153(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面
数据库·学习·ssm 框架·学生出国境管理·在线申请
chilavert3181 小时前
DashGO框架开发应用的笔记-1
笔记
航Hang*2 小时前
Photoshop 图形与图像处理技术——第9章:实践训练1——绘制禁烟标志和奥运五环
图像处理·笔记·学习·ui·photoshop
saoys2 小时前
Opencv 学习笔记:图像金字塔实现上采样(pyrUp)与降采样(pyrDown)
笔记·opencv·学习
大志若愚YYZ2 小时前
ROS2学习 C++中的this指针
c++·学习·算法
hhcccchh3 小时前
学习vue第十三天 Vue3组件深入指南:组件的艺术与科学
javascript·vue.js·学习
崔高杰3 小时前
【论文阅读笔记】Agent Memory相关文献追踪——异构存储和经验记忆相关
论文阅读·笔记