【数据结构】排序算法

简介: 【数据结构】排序算法

🎏排序的定义

排序是计算机程序设计中的一种重要操作,它的功能是将一个数据元素(或记录)的任意序列,重新排列成一个按关键字有序的序列.

排序的定义:

假设含n个记录的序列为 其相应的关键字序列为 需确定1,2,...,n的一种排列 ,使其相应的关键字满足如下的非递减(或非递增)关系.

,即使 成为一个按关键字有序的序列 ,这样一种操作称为排序.


🎏排序的稳定性

📌稳定性的定义

假设关键字序列为: ,其中 ,且在排序前的序列中 领先于 (即i<j).如果排序后 仍领先于 ,则称所用的排序方法是稳定的;反之,若可能使得排序后的序列中 领先 ,则称所用的排序方法是不稳定的.

📌稳定性的意义

排序稳定性主要是方便我们对一个复杂结构体进行副关键字辅助主关键字进行排序.

如下,是一份模拟考试的成绩单,可以看到,单按总分排名的话,就会出现有两人总分一致,然后并列排名的情况,于是我们为了在排名上区分出二者,就设定了一项规则:如果两人总分数一致,则比较两人语文成绩,语文成绩高则排名在前.像这种有主次性排序条件的多条件排序,我们通常需要借助稳定的排序算法先将数据按照副排序条件进行一次排序,再在此基础上按照主排序条件进行一次排序,这样得到的结果,就能够满足:主排序条件一致的情况下,同样满足副排序条件的数据在前的序列了.

  • 常见的稳定的排序算法有: 直接插入排序,冒泡排序,简单选择排序,归并排序,基数排序
  • 常见的不稳定的排序算法有:希尔排序,快速排序,堆排序,计数排序

🎏内排序与外排序

根据在排序过程中待排序的记录是否全部被放置在内存中,排序分为:内排序和外排序.

内排序是在排序的整个过程中,待排序的所有记录全部被放置在内存中.外排序是由于排序的记录个数太多,不能同时放置在内存,整个排序过程需要在内外存之间多次交换数据才能进行.


🎏八大内排序

📌冒泡排序

它的基本思想是:

  • 重复走访过要排序的数列,一次比较两个元素,如果他们的顺序错误就把他们交换过来。
  • 走访数列的工作是重复地进行直到没有再需要交换,也就是说该数列已经排序完成

算法演示动图如下:

算法单趟排序可视化过程:

有关冒泡排序的具体代码实现:

https://blog.csdn.net/weixin_72357342/article/details/129173919?spm=1001.2014.3001.5502


📌希尔排序

它的基本思想是:

  • 先选定一个整数,把待排序文件中所有数据分成gap个组,所有距离为gap的数据分在同一组内,并对每一组内的数据进行排序.
  • 重复上述分组和排序的工作,当达到gap=1时,所有数据在统一组内排好序.

算法动图演示如下:

算法单趟排序可视化过程(以gap/=2为例):

有关希尔排序的具体代码实现:

https://blog.csdn.net/weixin_72357342/article/details/135043566


📌直接插入排序

它的基本操作是:

  • 将一个数据插入到已经排好的有序表中,从而得到一个新的,数据数增1的有序表.
  • 直到所有的数据插入完为止,得到一个新的有序序列.

算法动图演示如下:

算法单趟排序可视化过程:

有关直接插入排序的具体代码实现:

https://blog.csdn.net/weixin_72357342/article/details/135038521?spm=1001.2014.3001.5502


📌简单选择排序

它的基本操作是:

  • 每一次通过n-i次关键字间的比较,从n-i+1个数据中选出关键字最小(大)的数据,并和第i(1≤i≤n)个数据交换
  • 重复n-1次上述操作,直到全部待排序的数据元素排完.

算法动图演示如下:

算法单趟排序可视化过程:

有关简单选择排序的具体代码实现:

https://blog.csdn.net/weixin_72357342/article/details/135059302?spm=1001.2014.3001.5502


📌堆排序

它的基本思想是:

  1. 将待排序的序列构造成一个大堆.(如果是降序则建小堆)
  2. 此时,整个序列的最大值就是堆顶的根结点.将它移走(其实就是我们前面堆实现中的出堆顶操作).
  3. 然后将剩余的n-1个序列重新构造成一个堆,这样就会得到n个元素中的次小值(即堆顶).
  4. 如此反复执行,就可以得到一个有序的序列了.

算法动图演示:

1.向下调整建堆

逻辑结构:

物理结构:

2.堆排序(升序)

逻辑结构:

物理结构:

算法单趟排序可视化过程:

有关直接插入排序的具体代码实现:

https://blog.csdn.net/weixin_72357342/article/details/135059322?spm=1001.2014.3001.5502


📌快速排序

它的基本思想是:

  • 通过一趟排序将待排数据分割成独立的两部分
  • 其中一部分数据的关键字均比另一部分数据的关键字小
  • 可分别对这两部分数据继续进行排序,以达到整个序列有序的目的.

算法动图演示:

算法单趟排序可视化过程:

有关快速排序的具体代码实现:

https://blog.csdn.net/weixin_72357342/article/details/135059337?spm=1001.2014.3001.5502


📌归并排序

归并排序(Merging Sort)就是利用归并的思想实现的排序方法.

它的原理是:

      假设初始序列含有n个记录,则可看成是n个有序的子序列,每个子序列的长度为1,然后两两归并,得到\left \lceil \frac{n}{2} \right \rceil(\left \lceil x \right \rceil表示不小于x的最小整数)个长度为2或1的有序子序列;再两两归并,......,如此重复,直至得到一个长度为n的有序序列为止,这种排序方法称为2路归并排序.

算法动图演示如下:

算法逻辑演示:

算法单趟排序可视化过程:

有关归并排序的具体代码实现:

【数据结构】八大排序算法之归并排序算法

https://blog.csdn.net/weixin_72357342/article/details/135059352


📌计数排序

计数排序的核心在于将输入的数据值转化为键存储在额外开辟的数组空间中。作为一种线性时间复杂度的排序,计数排序要求输入的数据必须是有确定范围的整数。

计数排序的实现思路:

  1. 统计每个数据出现的次数
  2. 按序输出

算法动图演示如下:

算法单趟排序可视化过程:

有关直接插入排序的具体代码实现:

【数据结构】八大排序之计数排序算法

https://blog.csdn.net/weixin_72357342/article/details/135059360


🎏结语

希望这篇八大排序算法简介能对大家有所帮助,欢迎大佬们留言或私信与我交流.

学海漫浩浩,我亦苦作舟!关注我,大家一起学习,一起进步!


数据结构排序算法篇思维导图:

 


相关文章
|
1月前
|
存储 人工智能 算法
数据结构与算法细节篇之最短路径问题:Dijkstra和Floyd算法详细描述,java语言实现。
这篇文章详细介绍了Dijkstra和Floyd算法,这两种算法分别用于解决单源和多源最短路径问题,并且提供了Java语言的实现代码。
69 3
数据结构与算法细节篇之最短路径问题:Dijkstra和Floyd算法详细描述,java语言实现。
|
1月前
|
机器学习/深度学习 存储 缓存
数据结构与算法学习十:排序算法介绍、时间频度、时间复杂度、常用时间复杂度介绍
文章主要介绍了排序算法的分类、时间复杂度的概念和计算方法,以及常见的时间复杂度级别,并简单提及了空间复杂度。
25 1
数据结构与算法学习十:排序算法介绍、时间频度、时间复杂度、常用时间复杂度介绍
|
1月前
|
存储 算法 Java
Set接口及其主要实现类(如HashSet、TreeSet)如何通过特定数据结构和算法确保元素唯一性
Java Set因其“无重复”特性在集合框架中独树一帜。本文解析了Set接口及其主要实现类(如HashSet、TreeSet)如何通过特定数据结构和算法确保元素唯一性,并提供了最佳实践建议,包括选择合适的Set实现类和正确实现自定义对象的hashCode()与equals()方法。
32 4
|
1月前
|
搜索推荐 算法
数据结构与算法学习十四:常用排序算法总结和对比
关于常用排序算法的总结和对比,包括稳定性、内排序、外排序、时间复杂度和空间复杂度等术语的解释。
20 0
数据结构与算法学习十四:常用排序算法总结和对比
|
1月前
|
存储 缓存 分布式计算
数据结构与算法学习一:学习前的准备,数据结构的分类,数据结构与算法的关系,实际编程中遇到的问题,几个经典算法问题
这篇文章是关于数据结构与算法的学习指南,涵盖了数据结构的分类、数据结构与算法的关系、实际编程中遇到的问题以及几个经典的算法面试题。
29 0
数据结构与算法学习一:学习前的准备,数据结构的分类,数据结构与算法的关系,实际编程中遇到的问题,几个经典算法问题
|
1月前
|
机器学习/深度学习 存储 算法
【数据结构与算法基础】——算法复杂度
【数据结构与算法基础】——算法复杂度
|
1月前
|
机器学习/深度学习 存储 算法
【初阶数据结构】算法效率大揭秘 | 时间与空间复杂度的深度剖析
【初阶数据结构】算法效率大揭秘 | 时间与空间复杂度的深度剖析
|
1月前
|
机器学习/深度学习 搜索推荐 算法
探索数据结构:初入算法之经典排序算法
探索数据结构:初入算法之经典排序算法
|
1月前
|
算法 Java 索引
数据结构与算法学习十五:常用查找算法介绍,线性排序、二分查找(折半查找)算法、差值查找算法、斐波那契(黄金分割法)查找算法
四种常用的查找算法:顺序查找、二分查找(折半查找)、插值查找和斐波那契查找,并提供了Java语言的实现代码和测试结果。
20 0
|
1月前
|
存储 算法 Java
数据结构和算法--分段树
数据结构和算法--分段树
16 0