排序算法

✍ dations ◷ 2025-09-04 18:01:01 #排序算法

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

相关

  • 温泉红藻纲温泉红藻(Cyanidiophyceae,简称Cyanidia)是一群生活在高温高酸环境中的单细胞红藻,主要分布于世界各地火山活动仍然活跃,并具有硫酸成分高之温泉水体之地区,如美国黄石国家公园
  • 1401年重要事件及趋势重要人物
  • 普锐特冶金技术普锐特冶金技术有限公司是从事冶金设备设计和制造的世界三巨头公司之一。现为日本三菱重工业的全资子公司,业务总部位于奥地利林茨。业务范围涵盖整个钢铁生产工艺流程。在线
  • 普拉多博物馆普拉多博物馆(西班牙语:Museo Nacional del Prado),又译作普拉多美术馆,馆舍位于西班牙马德里,是该国最大的美术馆,收藏有从14世纪到19世纪来自全欧洲的绘画、雕塑和各类工艺品,是当
  • 袁应泰袁应泰(?-1621年),字大来,号位宇,陕西凤翔县人。晚明政治人物。袁应泰于万历二十三年(1595年)中进士,授临漳知县,任内筑长堤四十余里,捍御漳水。迁工部主事,起用河南右参政,官至兵部侍郎。
  • 古波斯波斯(Persia)是伊朗在欧洲的古希腊语和拉丁语的旧称译音,是伊朗历史的一部分。历史上在这一西南亚地区曾建立过多个的帝国。全盛时期领土东至印度河平原,西北至小亚细亚、欧洲的
  • 西泽润一西泽润一(日语:西澤 潤一/にしざわ じゅんいち Nishizawa Jun'ichi ?,1926年9月12日-2018年10月21日),日本工程学、物理学家与教育家。生前为上智大学特聘教授、日本东北大学名誉
  • 印度尼西亚人口印度尼西亚是世界第四人口大国,2.536多亿人口散居在约6000个岛屿上。印尼也是一个多民族的国家,有100多个民族,其中爪哇族占总人口的40.6%,华裔占1.2%。全国约87.2%的居民信奉伊
  • 娘惹菜娘惹菜是流行于东南亚新加坡,马来西亚,印度尼西亚和泰国等地的美食。起源来自于早期定居于槟城,马六甲,新加坡的中国移民。娘惹菜取名于娘惹,指的是中国移民和马来原住民通婚的女
  • 赫尔曼·施陶丁格赫尔曼·施陶丁格(德语:Hermann Staudinger,1881年3月23日-1965年9月8日),德国化学家,在高分子化学领域作出了开拓性贡献,被授予1953年诺贝尔化学奖。1881年施陶丁格出生在德国莱茵