开发者社区> 问答> 正文

数据结构的排序算法中,哪些排序是稳定的,哪些排序是不稳定的?

如题~

展开
收起
知与谁同 2018-07-18 20:24:00 2261 0
2 条回答
写回答
取消 提交回答
  • 阿里云开发者社区运营负责人。原云栖社区负责人。
    直接插入 稳定直接选择 不稳定(很多书上这么说,但我总觉得是稳定的)冒泡 稳定希尔 不稳定快速 不稳定堆 不稳定归并 稳定
    2019-07-17 22:49:36
    赞同 展开评论 打赏
  • 这个时候,玄酱是不是应该说点什么...

    快速排序、希尔排序、堆排序、直接选择排序不是稳定的排序算法。

    基数排序、冒泡排序、直接插入排序、折半插入排序、归并排序是稳定的排序算法。

    1.所谓排序,就是使一串记录,按照其中的某个或某些关键字的大小,递增或递减的排列起来的操作。排序算法,就是如何使得记录按照要求排列的方法。排序算法在很多领域得到相当地重视,尤其是在大量数据的处理方面。一个优秀的算法可以节省大量的资源。

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

    3.稳定度(稳定性)

    一个 排序算法是 稳定的,就是当有两个相等记录的关键字 和 ,且在原本的列表中 出现在 之前,在排序过的列表中 也将会是在 之前。

    当相等的元素是无法分辨的, 比如像是整数,稳定度并不是一个问题。然而,假设以下的数对将要以他们的第一个数字来 排序。

    4.不稳定 排序算法可能会在相等的键值中改变纪录的相对次序,但是稳定排序算法从来不会如此。不稳定 排序算法可以被特别地实现为稳定。作这件事情的一个方式是人工扩充键值的比较,如此在其他方面相同键值的两个对象间之比较,就会被决定使用在原先数据次序中的条目,当作一个同分决赛。然而,要记住这种次序通常牵涉到额外的空间负担。

    2019-07-17 22:49:36
    赞同 展开评论 打赏
问答排行榜
最热
最新

相关电子书

更多
如何打造一支优秀的人工智能算法团队 立即下载
海量数据场景下的淘宝搜索智能——算法及实践 立即下载
Apache Flink 流式应用中状态的数据结构定义升级 立即下载