【408数据结构与算法】—排序(十四)

简介: 排序:将一组杂乱无章的数据按一定规律排列起来。即将无序序列排列成一个有序序列(由小到大或由大到小)的运算。

【408数据结构与算法】—排序(十四)

一、什么是排序

排序:将一组杂乱无章的数据按一定规律排列起来。即将无序序列排列成一个有序序列(由小到大或由大到小)的运算。如果参加排序的数据结点包含多个数据域,那么排序往往是针对其中某个域而言的。

二、排序的应用

2345_image_file_copy_284.jpg

2345_image_file_copy_285.jpg

三、排序方法的分类

  • 按数据存储介质分类:内部排序和外部排序
  • 按比较个数:串行排序和并行排序
  • 按主要操作:比较排序和基数排序
  • 按辅助空间:原地排序和非原地排序
  • 按稳定性:稳定排序和非稳定排序
  • 按自然性:自然排序和非自然排序

1️⃣按存储介质分为

  • 内部排序:数据量不大,数据在内存,无需内外存交换数据
  • 外部排序:数据量大,数据在外存(文件排序)
  • 外部排序时,要将数据分批调入内存来排序,中间结果还要及时放入外存,显然外部排序要复杂的多。

2️⃣按比较器个数分为

  • 串行排序:单处理机(同一时刻比较一对元素)
  • 并行排序:多处理机(同一时刻比较多对元素)

3️⃣按主要操作分类

  • 比较排序:用比较的方法(插入排序、交换排序、选择排序、归并排序)
  • 基数排序:不比较元素的大小,仅仅是根据元素本身的取值确定其有序位置

4️⃣按辅助空间可以分为:

  • 原地排序:辅助空间用量为O(1)的排序方法(所占的辅助存储空间与参加排序的数据量大小无关)
  • 非原地排序:辅助空间用量超过O(1)的排序方法

5️⃣按稳定性可分为

  • 稳定排序:能够使任何数值相等的元素,排序以后相对次序不变
  • 非稳定排序:不是稳定排序的方法

2345_image_file_copy_286.jpg

排序的稳定性只对结构类型的数据排序有意义

2345_image_file_copy_287.jpg

6️⃣按自然性分为:

  • 自然排序:输入数据越有序,排序的速度越快的排序方法
  • 非自然排序:不是自然排序的方法

四、按排序依据原则

  • 插入排序:直接插入排序、折半插入排序、希尔排序
  • 交换排序:冒泡排序、快速排序
  • 选择排序:简单选择排序、堆排序
  • 归并排序:2路归并排序
  • 基数排序

五、那排序所需的工作量

2345_image_file_copy_288.jpg

六、存储结构—记录序列以顺序表存储

2345_image_file_copy_289.jpg

2345_image_file_copy_290.jpg

2345_image_file_copy_291.jpg


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