排序算法

✍ dations ◷ 2025-02-23 22:32:38 #排序算法

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

相关

  • 进化 (消歧义)演化、演变、演进、是翻译自英文“Evolution”,这个字有许多意义,其中包括许多作品。以下名单为列举 ,关于更多以Evolution为名的事物,可参考其他语言版本。
  • 沈立沈立(1007年-1078年),字立之,历阳(今安徽和县)人。祖父沈仁谅始定居历阳。早孤,由母亲养大。宋仁宗天圣八年王拱辰榜进士,历任桐城尉,畿县主薄,有政绩。通判寿州。签书益州判官,提举澶州
  • 科威特市科威特城(阿拉伯语:مدينة الكويت)位于科威特东部波斯湾畔,是科威特的首都和首都省的首府。http://www.hko.gov.hk/wxinfo/climat/world/chi/asia/westasia/kuwait_c.
  • 树叶叶是高等植物的营养器官,侧边发育自植物的茎的叶原基。叶内含有叶绿体,是植物进行光合作用的主要场所。同时,植物的蒸散作用是通过叶的气孔实现的。叶只出现在真正的茎上,即只有
  • 马里华人,在马里大约只占人口3000人,多数生活在首都巴马科。但他们经济表现突出,他们主要经营零售,医疗和建造业,同时也经营私家诊所。华人最早是在20世纪90年代来到马里。在2005年他
  • 深海长眠《深海长眠》(西班牙语:Mar adentro,英语:The Sea Inside)是西班牙导演亚历杭德罗·亚梅涅巴于2004年拍摄的影片。影片取材于西班牙人拉蒙·桑佩德罗(西班牙语:Ramón Sampedro)的真
  • 亨顿坐标:51°35′01″N 0°13′31″W / 51.5837°N 0.2252°W / 51.5837; -0.2252亨顿(Hendon),或译亨通、亨登,是英国伦敦北部巴尼特区的一个地区,是原来的米德尔塞克斯的教区,1965年
  • 东高止山东高止山脉是印度的山脉,位于该国东岸,全长约1,500公里,横跨奥里萨邦、安得拉邦、卡纳塔克邦和泰米尔纳德邦,最高点海拔高度1,680米。
  • 漫画威龙《漫画威龙》(英文:Fist of Fury 1991 II)是电影《新精武门1991》的续集,又名《新精武门1992》,导演为左颂昇,由周星驰、张敏、锺镇涛、萧芳芳、陈百祥以及元华等人主演。牛皮(陈百
  • 卡斯泰克卡斯泰克(英语:Castaic)是位于美国加利福尼亚州洛杉矶县的一个人口普查指定地区。卡斯泰克的座标为34°28′15″N 118°37′41″W / 34.47083°N 118.62806°W / 34.47083; -11