排序算法

✍ dations ◷ 2025-06-29 00:26:43 #排序算法

在计算机科学与数学中,一个排序算法(英语: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} 是不同键值的数量。

相关

  • 肉类肉类食物,或者简称肉类或荤菜,是从各种动物身上可供食用的肉及一些其他组织,经过不同程度及方法的加工,成为不同种类的肉类食物。常见的肉类包括猪肉、牛肉、羊肉、狗肉以及鸡肉
  • 类人猿类人猿下目(学名:Simiiformes)是一类高等灵长类,由旧世界猴及猿组成。它们比原猴亚目的要大。类人猿下目分成三类。阔鼻小目于约4000万年前分支出来,只余下狭鼻小目留在旧世界。
  • 法兰克福宪法保罗教堂宪法(保罗教会宪法) (Paulskirchenverfassung)是第一部整个德国范围的由民主决议产生的宪法,然而这部宪法却从来没有生效过。它作为“德意志帝国宪法”于1849年3月27日
  • 索道索道又称吊车、空中缆车、流笼(缆车又可以指缆索铁路),是交通工具的一种,通常在崎岖的山坡上运载乘客或货物上下山。索道是利用悬挂在半空中的钢索,承托及牵引客车或货车。除了车
  • 作秀公审摆样子公审(show trial),又译作秀公审、作秀审判,是一个对某种高度公开审判的贬义提法。在此种类型的审判中,有明显迹象可以表明司法当局已经提前定了被告人的罪。此审判唯一的目
  • 圣克拉拉轻轨圣克拉拉轻轨(英语:VTA Light Rail),全称是圣克拉拉谷交通局轻轨(Santa Clara Valley Transportation Authority light rail) ,是在美国加利福利亚州圣何塞及圣克拉拉地区(硅谷)由圣
  • 比尔·克林顿比尔·克林顿,全名威廉·杰斐逊·克林顿(英语:William Jefferson Clinton,1946年8月19日-)是美国律师、政治人物,民主党成员,曾长期担任阿肯色州州长(1979年-1981年、1983年-1992年)和第
  • 弗伦克尔缺陷弗伦克尔缺陷(英文 或 )是指晶体结构中由于原先占据一个格点的原子(或离子)离开格点位置,成为间隙原子(或离子),并在其原先占据的格点处留下一个空位(晶格空位),这样的晶格空位-间隙
  • 韦尔斯利 (马萨诸塞州)韦尔斯利镇(英语:Wellesley)是美国马萨诸塞州诺福克县中的一个镇。据美国2000年人口普查,该镇的人口为26,613。坐标:42°18′23″N 71°17′16″W / 42.306263°N 71.287772°W /
  • ATC代码 (B06)A·B·C·D·G·H·QI·J·L·M·N·P·R·S·VATC代码B06(其它血液学药剂)是解剖学治疗学及化学分类系统的一个药物分组,这是由世界卫生组织药物统计方法整合中心(The WHO Coll