排序算法

✍ dations ◷ 2025-06-08 07:15:53 #排序算法

在计算机科学与数学中,一个排序算法(英语:Sorting algorithm)是一种能将一串数据依照特定排序方式进行排列的一种算法。最常用到的排序方式是数值顺序以及字典顺序。有效的排序算法在一些算法(例如搜索算法与合并算法(英语:Merge algorithm))中是重要的,如此这些算法才能得到正确解答。排序算法也用在处理文字数据以及产生人类可读的输出结果。基本上,排序算法的输出必须遵守下列两个原则:

虽然排序算法是一个简单的问题,但是从计算机科学发展以来,在此问题上已经有大量的研究。举例而言,冒泡排序在1956年就已经被研究。虽然大部分人认为这是一个已经被解决的问题,有用的新算法仍在不断的被发明。(例子:图书馆排序在2004年被发表)

在计算机科学所使用的排序算法通常被分类为:

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

                    (        4        ,        1        )        (        3        ,        1        )        (        3        ,        7        )        (        5        ,        6        )              {\displaystyle (4,1)(3,1)(3,7)(5,6)}  

在这个状况下,有可能产生两种不同的结果,一个是让相等键值的纪录维持相对的次序,而另外一个则没有:

                    (        3        ,        1        )        (        3        ,        7        )        (        4        ,        1        )        (        5        ,        6        )              {\displaystyle (3,1)(3,7)(4,1)(5,6)}   (維持次序)                    (        3        ,        7        )        (        3        ,        1        )        (        4        ,        1        )        (        5        ,        6        )              {\displaystyle (3,7)(3,1)(4,1)(5,6)}   (次序被改變)

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

在这个表格中, n {\displaystyle n} 是要被排序的纪录数量以及 k {\displaystyle k} 是不同键值的数量。

相关

  • 葛伦克劳狄乌斯·盖伦(129年-200年)是一位古罗马的医学家及哲学家。他的见解和理论在他身后的一千多年里是欧洲起支配性的医学理论。出生于别迦摩,逝世于罗马。盖伦出生于一个建筑师
  • EBV人类疱疹病毒第四型(拉丁语:Epstein-Barr virus,缩写EBV、爱泼斯坦-巴尔病毒、 human herpesvirus 4 (HHV-4)),又称为EB病毒,是最常见能引起人类疾病的病毒之一。EBV是在公元1964
  • Ar氩(原子量:39.948(1))共有25个同位素,其中有3个是稳定的。备注:画上#号的数据代表没有经过实验的证明,只是理论推测而已,而用括号括起来的代表数据不确定性。
  • 德布罗意-玻姆理论一般认为,德布罗意-玻姆理论是一种量子力学诠释。亦称因果性诠释(Causal Interpretation)、存在性诠释(Ontological Interpretation)、玻姆诠释、玻姆力学(Bohmian Mechanics),有时
  • 俾路支人超过1500万伊斯兰教(多为逊尼派,少数Zikri教派(英语:Zikri)俾路支(俾路支语: بلوچ‬)是伊朗人一支,俾路支地区(西南亚伊朗高原地带)的主要民族。现主要分布在巴基斯坦、伊朗、阿富
  • 莞草莞(学名:Schoenoplectus tabernaemontani or Schoenoplectus validus),又名水葱、大水莞,为莎草科拟莞属下的一个种。
  • 阿拉伯马格里布联盟阿拉伯马格里布联盟(英语:Arab Maghreb Union,缩写:AMU)是一个马格里布阿拉伯国家政府间国际组织。马格里布是北非地区的阿拉伯国家的代称。1989年,在卡扎菲的发起下,摩洛哥、阿尔
  • 蒙特罗斯县蒙特罗斯县(英语:Montrose County)是美国科罗拉多州西部的一个县,西邻犹他州。面积5,808平方公里。根据美国2000年人口普查,共有人口33,432人。县治蒙特罗斯(Montrose)。蒙特罗斯县
  • M42清道夫M42 40毫米防空炮车(英语:M42 40 mm Self-Propelled Anti-Aircraft Gun),又称M42清道夫(英语:M42 Duster),为美国通用汽车公司于1951年以M19A1的炮塔与M41轻型战车为底盘改良而成。
  • 曲阜坐标:35°35′30.07″N 116°59′03.42″E / 35.5916861°N 116.9842833°E / 35.5916861; 116.9842833曲阜市位于中国山东省南部,是济宁市代管的一个县级市。曲阜是一个古老