数据结构 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 小时前
LeetCode Hot100数据结构背景知识之元组(Tuple)Python2026新版
数据结构·python·算法·leetcode·元组·tuple
risc1234561 小时前
认识一个事物,需要哪些基本能力与要素?
笔记
代码游侠2 小时前
C语言核心概念复习——C语言基础阶段
linux·开发语言·c++·学习
dingdingfish2 小时前
Bash学习 - 第3章:Basic Shell Features,第5节:Shell Expansions
开发语言·学习·bash
firewood20242 小时前
共射三极管放大电路相关情况分析
笔记·学习
zl0_00_02 小时前
美亚2023
学习
静听山水2 小时前
Redis核心数据结构-ZSet
数据结构·redis
AI_56782 小时前
SQL性能优化全景指南:从量子执行计划到自适应索引的终极实践
数据库·人工智能·学习·adb
zl0_00_02 小时前
pctf wp
学习
铉铉这波能秀2 小时前
LeetCode Hot100数据结构背景知识之字典(Dictionary)Python2026新版
数据结构·python·算法·leetcode·字典·dictionary