学习笔记--数据结构与算法基础(青岛大学-王卓)--第八章排序

简介: 学习笔记--数据结构与算法基础(青岛大学-王卓)--第八章排序

视频链接:
在这里插入图片描述
学习链接:数据结构与算法基础(青岛大学-王卓)--第八章排序

本章知识框架
在这里插入图片描述

1.基本概念和排序方法概述

  • 什么是排序?

在这里插入图片描述

  • 排序方法的分类

在这里插入图片描述

内部排序和外部排序(按存储介质划分)
内部排序:在内存中进行排序
外部排序:将外部存储的数据传到内存中进行排序,排好后再交给外存
在这里插入图片描述
串行排序和并行排序(根据比较器来划分)
在这里插入图片描述
比较排序和基数排序(按操作来划分)
在这里插入图片描述
原地排序和非原地排序(按辅助空间来划分)
在这里插入图片描述
稳定排序和非稳定排序
在这里插入图片描述
例子:
稳定排序:
在这里插入图片描述
在这里插入图片描述

非稳定排序:
在这里插入图片描述
自然排序和非自然排序
在这里插入图片描述

  • 按排序依据原则和按排序所需工作量(学习相关排序算法)

在这里插入图片描述

2.插入排序

  • 基本思想

在这里插入图片描述

  • 插入操作

插入的位置:
在这里插入图片描述
如何查找插入的位置:
在这里插入图片描述

  • 直接插入排序

在这里插入图片描述
改进一下:
在这里插入图片描述
算法:
在这里插入图片描述

效率

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

  • 二分插入排序

在这里插入图片描述
算法:
在这里插入图片描述
算法分析:
在这里插入图片描述
在这里插入图片描述

  • 希尔排序

在这里插入图片描述
基本思想:
在这里插入图片描述
例子:
在这里插入图片描述
在这里插入图片描述
特点:
在这里插入图片描述
算法:
在这里插入图片描述
在这里插入图片描述
算法分析:
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

3.交换排序

  • 基本思想

在这里插入图片描述

  • 冒泡排序

基本思想:
在这里插入图片描述
规律:
在这里插入图片描述
算法:
在这里插入图片描述
算法改进:
在这里插入图片描述
算法分析:
在这里插入图片描述

  • 快速排序

基本思想:
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
步骤:
在这里插入图片描述
算法:
在这里插入图片描述
在这里插入图片描述
算法分析:
在这里插入图片描述
在这里插入图片描述
快速排序不适于对原本有序或基本有序的记录序列进行排序。
在这里插入图片描述
在这里插入图片描述

4.选择排序

  • 简单选择排序

基本思想:
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
算法:
在这里插入图片描述
算法分析:
在这里插入图片描述

  • 堆排序

堆的定义:
在这里插入图片描述
例子:
在这里插入图片描述
在这里插入图片描述
堆排序:
在这里插入图片描述
实现堆排序需要解决的二个问题:
在这里插入图片描述
解决问题2:
在这里插入图片描述
例子:
在这里插入图片描述
输出堆顶元素
在这里插入图片描述
取堆中最后一个元素替代
在这里插入图片描述
比较其左右孩子值的大小,并与其中较小者交换
在这里插入图片描述
没有到达叶子,继续循环
在这里插入图片描述
再次输出堆顶元素,依次循环以上操作
解决问题1:
堆的建立
在这里插入图片描述
在这里插入图片描述
调整从第n/2个元素开始,将以该元素为根的二叉树调整为堆
在这里插入图片描述
在这里插入图片描述
将以序号为n/2 -1的结点为根的二叉树调整为堆
在这里插入图片描述
在这里插入图片描述
再将以序号为n/2-2的结点为根的二叉树调整为堆(无需调整38<49,38<76)
在这里插入图片描述
再将以序号为n/2-3的结点为根的二叉树调整为堆
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
实现:
在这里插入图片描述
进行堆排序
在这里插入图片描述
算法:
在这里插入图片描述
算法分析:
在这里插入图片描述

5.归并排序

  • 基本思想

在这里插入图片描述
例子:
在这里插入图片描述

  • 如何将二个有序序列合成一个有序序列

在这里插入图片描述
在这里插入图片描述

  • 算法分析

在这里插入图片描述

6.基数排序

  • 基本思想

在这里插入图片描述
例子:
按个位有序分配,按十位有序分配,按百位有序分配
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

  • 算法分析

在这里插入图片描述
在这里插入图片描述

7.外排序

外部排序指的是大文件的排序,即待排序的记录存储在外存储器上,待排序的文件无法一次装入内存,需要在内存和外部存储器之间进行多次数据交换,以达到排序整个文件的目的。

学习链接:外部排序算法总结

8.各种基本排序总结

  • 各种基本排序算法的比较

在这里插入图片描述

  • 时间性能上看各种排序算法

在这里插入图片描述
在这里插入图片描述

  • 空间性能上看各种排序算法

在这里插入图片描述

  • 各种排序算法的稳定性能

在这里插入图片描述

  • 各个排序算法的时间复杂度的下限(最坏时间复杂度)

在这里插入图片描述

相关文章
|
2月前
|
算法 C++
【洛谷 P1223】排队接水(贪心算法+结构体排序)
该问题要求安排$n$个人的排队顺序以最小化平均等待时间。每个人接水需时$T_i$,解决方案是让接水时间短的人优先。给定$n\leq1000$和$t_i\leq10^6$,代码示例使用C++实现,通过排序使时间从小到大排列,然后计算平均等待时间。样例输入为10个人的时间数组,输出为优化后的排队顺序及平均等待时间(291.90)。
27 0
|
6天前
|
搜索推荐 算法 测试技术
【数据结构】排序
【数据结构】排序
|
6天前
|
算法
【算法】二分查找——在排序数组中查找元素的第一个和最后一个位置
【算法】二分查找——在排序数组中查找元素的第一个和最后一个位置
|
6天前
|
搜索推荐 算法 Java
现有一个接口DataOperation定义了排序方法sort(int[])和查找方法search(int[],int),已知类QuickSort的quickSort(int[])方法实现了快速排序算法
该博客文章通过UML类图和Java源码示例,展示了如何使用适配器模式将QuickSort类和BinarySearch类的排序和查找功能适配到DataOperation接口中,实现算法的解耦和复用。
现有一个接口DataOperation定义了排序方法sort(int[])和查找方法search(int[],int),已知类QuickSort的quickSort(int[])方法实现了快速排序算法
|
12天前
|
算法 关系型数据库 MySQL
揭秘MySQL中的版本号排序:这个超级算法将颠覆你的排序世界!
【8月更文挑战第8天】在软件开发与数据管理中,正确排序版本号对软件更新及数据分析至关重要。因MySQL默认按字符串排序版本号,可能出现&#39;1.20.0&#39;在&#39;1.10.0&#39;之前的不合理情况。解决办法是将版本号各部分转换为整数后排序。例如,使用`SUBSTRING_INDEX`和`CAST`函数从`software`表的`version`字段提取并转换版本号,再按这些整数排序。这种方法可确保版本号按逻辑正确排序,适用于&#39;major.minor.patch&#39;格式的版本号。对于更复杂格式,需调整处理逻辑。掌握此技巧可有效应对版本号排序需求。
39 3
|
1月前
|
搜索推荐
【数据结构常见七大排序(三)上】—交换排序篇【冒泡排序】And【快速排序】
【数据结构常见七大排序(三)上】—交换排序篇【冒泡排序】And【快速排序】
【数据结构常见七大排序(三)上】—交换排序篇【冒泡排序】And【快速排序】
|
5天前
|
算法 搜索推荐
算法设计 (分治法应用实验报告)基于分治法的合并排序、快速排序、最近对问题
这篇文章是关于分治法应用的实验报告,详细介绍了如何利用分治法实现合并排序和快速排序算法,并探讨了使用分治法解决二维平面上的最近对问题的方法,包括伪代码、源代码实现及时间效率分析,并附有运行结果和小结。
|
11天前
|
存储 算法 Java
LeetCode初级算法题:反转链表+统计N以内的素数+删除排序数组中的重复项Java详解
LeetCode初级算法题:反转链表+统计N以内的素数+删除排序数组中的重复项Java详解
10 0
|
1月前
|
存储 算法 搜索推荐
算法进阶之路:Python 归并排序深度剖析,让数据排序变得艺术起来!
【7月更文挑战第12天】归并排序是高效稳定的排序算法,采用分治策略。Python 实现包括递归地分割数组及合并已排序部分。示例代码展示了如何将 `[12, 11, 13, 5, 6]` 分割并归并成有序数组 `[5, 6, 11, 12, 13]`。虽然 $O(n log n)$ 时间复杂度优秀,但需额外空间,适合大规模数据排序。对于小规模数据,可考虑其他算法。**
57 4
|
1月前
|
搜索推荐
【数据结构常见七大排序(二)】—选择排序篇【直接选择排序】And【堆排序】
【数据结构常见七大排序(二)】—选择排序篇【直接选择排序】And【堆排序】