1.简单选择排序 2.堆排序        (1和2是属于选择排序)

3.直接插入排序 4.希尔排序     (3和4属于插入排序,有时把改进后的直接插入排序叫做二分插入)

5.冒泡排序         6.快速排序     (5和6属于交换排序.交换排序顾名思义是不停的交换数据位置.但实际上选择排序也在不停的交换元素,但次数较少,只有找到最大值才一次交换.侧重点还是在通过遍历或堆来选择出最值.而冒泡排序就是通过不停交换相邻元素得出最大值,快速排序也在不停交换元素使序列一步步接近有序.侧重在交换)

7.基数排序       8.桶排序         (7和8属于分配排序)

9.归并排序

面对这以多排序算法你可能郁闷着要自己排序时用哪种算法好呢? 每种算法适用哪些场景?

为了对比上面各种不同算法,可以从如下几个方面来考虑.

1.排序算法的稳定性

2.排序算法时间复杂度

3.排序算法空间复杂度

4.各种算法适用的最佳场景.

排序算法稳定性

所谓稳定性是指待排序的序列中有两元素相等,排序之后它们的先后顺序不变.假如为A1,A2.它们的索引分别为1,2.则排序之后A1,A2的索引仍然是1和2.

稳定也可以理解为一切皆在掌握中,元素的位置处在你在控制中.而不稳定算法有时就有点碰运气,随机的成分.当两元素相等时它们的位置在排序后可能仍然相同.但也可能不同.是未可知的.

另外要注意的是:算法思想的本身是独立于编程语言的,所以你写代码去实现算法的时候很多细节可以做不同的处理.采用不稳定算法不管你具体实现时怎么写代码,最终相同元素位置总是不确定的(可能位置没变也可能变了).而稳定排序算法是你在具体实现时如果细节方面处理的好就会是稳定的,但有些细节没处理得到的结果仍然是不稳定的.

比如冒泡排序,直接插入排序,归并排序虽然是稳定排序算法,但如果你实现时细节没处理好得出的结果也是不稳定的.

稳定性的用处

我们平时自己在使用排序算法时用的测试数据就是简单的一些数值本身.没有任何关联信息.这在实际应用中一般没太多用处.实际应该中肯定是排序的数值关联到了其他信息,比如数据库中一个表的主键排序,主键是有关联到其他信息.另外比如对英语字母排序,英语字母的数值关联到了字母这个有意义的信息.

可能大部分时候我们不用考虑算法的稳定性.两个元素相等位置是前是后不重要.但有些时候稳定性确实有用处.它体现了程序的健壮性.比如你网站上针对最热门的文章或啥音乐电影之类的进行排名.由于这里排名不会像我们成绩排名会有并列第几名之说.所以出现了元素相等时也会有先后之分.如果添加进新的元素之后又要重新排名了.之前并列名次的最好是依然保持先后顺序才比较好.

哪些算法是稳定的呢

稳定性算法:   基数排序 , 直接插入排序 , 冒泡排序, 归并排序

不稳定性算法: 桶排序,    二分插入排序,希尔排序, 快速排序,   简单选择排序,堆排序

各种算法稳定性详解

(1)基数排序(稳定)与桶排序(不稳定)

这两种算法都是属于分配排序算法.(利用元素值本身的信息直接映射到一个辅助序列中变成有序的.而不是通过与其他元素比较确定顺序位置)

基数排序因为在是把低位按顺序映射到一个临时序列中去,是依次序映射,没有涉及到数据位置的变动.然后再按高位顺序映射.所以相同元素也是按次序映射过去.所以是稳定的

如果数据元素没有重复的则采用简单桶排序,此时没有重复元素,所以自然不存在稳不稳定这一说.如果有重复元素得用改进的桶排序.此时辅助的临时数组只是通过索引来识别待排序元素的键值.丢失了其他信息(这是所有采用辅助的临时序列的算法中唯一一个会丢失信息的算法).假如待排序元素是一个map类型,按它的键值来排序.其他算法采用辅助序列时是把map类型做为元素去考虑的.而只有改进的桶排序不会把map类型当元素,只是利用到了键值信息. 这样一来就无法区分键值相同的信息,因此自然是不稳定的算法了啊.

(2)归并排序(稳定)

归并排序使得了递归的思想,把序列递归的分割成小序列,然后合并排好序的子序列.当有序列的左右两子序列合并的时候一般是先遍历左序列,所在左右序列如果有相等元素,则处在左边的仍然在前,这就稳定了.但是如果你非得先遍历右边序列则算法变成不稳定的了.虽然这样排出来的序也是对的,但变成了不稳定的,所以是不太好的实现.

(3)简单选择排序(不稳定)与堆排序(不稳定)

这两种算法都属于选择排序.(从待排序的元素中挑选出最大或最小值.下面的例子以最小值为例)

简单选择排序由于选出最小值后需要交换位置,位置一变就会变得不稳定.例如8  3  8  1.当从左往右遍历找最小值时,找到了1,这就需要把8跟1交换.这样两个相等元素8的位置就变了.

堆排序的话,也会存在跟上面一样的交换最大值的位置会导致不稳定.例如有大堆 8 8 6 5 2.先选出第一个最大值8,放最末尾.此时就不稳定了.因为第二个8就跑它前面去了.

(4)冒泡排序(稳定)与快速排序(不稳定)

这两种算法都属于交换排序.

冒泡是通过不停的遍历,以升序为例,如果相邻元素中左边的大于右边的则交换.碰到相等的时就不交换保持原位.所以是稳定的.当然如果你非得吃饱了撑着了,在碰到相等的时也交换下,那肯定变成不稳定的算法了.

快速排序是不稳定的.举例8   5   6  6 .以8为基准,第一趟交换后最后一个6跑到第一位,8到最后.第二趟交换.这个6跑到5的位置.变成有序的了.两个6位置变了,所以是不稳定的.

(5)直接插入(稳定),二分插入排序(不稳定)与希尔排序(不稳定)

直接插入时是先在已排序好的的子序列中找到合适的位置再插入.假设左边是已排序的,右边是没排序的.通过从后向前遍历已排序序列,然后插入,此时相等元素依然可以保持原有位置.但是如果你从前向后遍历已排序序列就会是不稳定排序了.

二分插入排序是不稳定的,因为通过二分查找时得到的位置不稳定.例如3 4 4 5 4.但把最后一个4插入时肯定会跑到第二个4前面去了.所以是不稳定的.

通过上面的分析我们可以得出这样一个经验之谈.

1.只要不涉及到两个元素之间位置的交换就肯定是稳定的排序算法.比如归并排序,基数排序.(桶排序不稳定是个特例,因为它丢失了附带信息,不然的话可以弄成稳定排序的)

2.在涉及到不同位置元素交换的算法中除了冒泡和直接插入排序是稳定的,其他都是不稳定的.

你可以这样想,之所以出现相同元素位置变了就是其中一个交换位置时从另一个头顶跳过去了,而冒泡算法是相邻位置互换,跳不过去的,碰到相等元素的时候就停住不交换了.

而直接插入排序是往已排好序的序列中插入.所以你通过由后往前遍历碰到相等的时就停住,这样也能保持稳定.但记住一定得从后往前遍历,不然也会不稳定.(所以说直接插入是半稳吧,而冒泡是非常的稳啊,除非你闲得蛋痛非得把两相等的元素两两交换)

数据结构中各种排序算法的稳定性比较相关推荐

  1. 数据结构中各种排序算法比较

    数据结构中各种排序算法比较 1 快速排序(QuickSort)    快速排序是一个就地排序,分而治之,大规模递归的算法.从本质上来说,它是归并排序的就地版本.快速排序可以由下面四步组成. (1) 如 ...

  2. php实现数据排序算法,PHP实现数据结构中的排序算法_PHP教程

    直接插入排序为止. [代码实现] 实现:与增量间隔的数比较,直到把大的数放到最后 1) { $d=intval($d / 2);//分组间隔,2为n值,n值减少时,移动的趟数和数据增多 $temp=N ...

  3. 选择排序总结以及排序算法的稳定性

    选择排序介绍: 选择排序(Selection sort)是一种简单直观的排序算法.它的工作原理是每一次从待排序的数据元素中选出最小(或最大)的一个元素,存放在序列的起始(末尾)位置,直到全部待排序的数 ...

  4. 从数据预处理到排序算法,全方位解读 Uber AI客服系统 COTA

    文章来源:ATYUN AI平台 Uber利用基于NLP和机器学习构建的COTA客服系统,可以快速高效地解决90%以上的客服问题. 为了打造最佳用户体验,Uber持续优化客户支持流程,让客户支持服务更易 ...

  5. 排序算法的总结 排序算法及其稳定性

    排序算法总结: 1.桶排序 2.选择排序 3.冒泡排序 4.插入排序 5.归并排序 6.希尔排序 7.快速排序 8.基数排序 9.堆排序 排序算法的稳定性通俗地讲就是能保证排序前2个相等的数其在序列的 ...

  6. 判断各种排序算法的稳定性

    排序算法稳定性 如果在一个待排序的序列中,存在2个相等的数,在排序后这2个数的相对位置保持不变,那么该排序算法是稳定的:否则是不稳定的. 举个例子 对五个同学(A,B,C,D,E)进行成绩排序,他们的 ...

  7. 【python】排序算法的稳定性冒泡排序(画图详细讲解)

    一.排序算法的稳定性 二.冒泡排序 a.重复比较相邻的元素,如果前面的比后面的大,就交换它们两个 b.每次遍历整个数组,遍历完成后,下一次遍历的范围往左缩1位 c.重复前面步骤,直到排序完成 三.代码 ...

  8. 数据结构与算法:排序算法的稳定性以及各性能比较python实现

    招聘笔试中经常会考到排序算法,在此做一个总结. 一.算法概念 1.排序算法的稳定性 假定在待排序的记录序列中,存在多个具有相同的关键字的记录,若经过排序,这些记录的相对次序保持不变,即在原序列中,r[ ...

  9. 什么是排序算法的稳定性?

    什么是排序算法的稳定性? 今天来了解一下排序算法的稳定性的定义和一些常见排序算法的稳定性,一起来看看吧! 我们知道排序算法有时间.空间复杂度,那稳定性是什么意思呢?和它们有关吗? 文章目录 什么是排序 ...

最新文章

  1. WordPress制作圆形头像友情链接页面的方法
  2. 为什么vs数据库中文显示问号_在vs2008中注册页面中的中文字符写入数据库的后中文会变成问号...
  3. 什么决定了程序员的价格,程序员该如何溢价
  4. python str转dict_在python中将str转换为dict
  5. 计算机专业毕业生管理制度,管理制度建设
  6. idea javamaven项目 连接sqlserver 数据库方法
  7. gensim训练word2vec并使用PCA实现二维可视化
  8. Maven多模块,Dubbo分布式服务框架,SpringMVC,前后端分离项目,基础搭建,搭建过程出...
  9. 读EasyPR开发详解实践感想1
  10. 单步ARM汇编解开volatile本质
  11. 实验1-6 输出带框文字
  12. VS2003一点查找按钮就卡死处理方法
  13. 硬件固件名称在软件测试中指什么,固态硬盘升级固件有什么用?固态硬盘怎么升级固件?...
  14. 图解千兆网线水晶头接法(存档备用)
  15. 如何用电路实现检测过零点?这个简单电路就能搞定
  16. html 颜色代码_HTML颜色(颜色代码)
  17. 异步获取到图虫上的图片
  18. 商业虚拟专用网络技术十三 BGP/MPLS报文转发
  19. java使用jacob将word,excel,ppt转成html
  20. audio应用-外接akm7755

热门文章

  1. 微信小程序开通直播的条件
  2. RK987蓝牙机械键盘win和alt键互换
  3. 大文件打包压缩成的几个小文件怎么解压?
  4. 棋盘覆盖问题——详解(C++)
  5. HDU - 1859 最小长方形
  6. 因为此版本的应用程序不支持其项目类型(.csproj)
  7. 快速配置Tomcat,解决Tomcat卡住不动
  8. 面向Python开发人员的综合置信区间全面理解
  9. 推荐|别让职业生涯规划毁掉你的成长
  10. Maven 标签scop值配置介绍