python 的 sorted() 函数保证稳定吗?

2025-02-24 09:29:00
admin
原创
65
摘要:问题描述:文档没有保证这一点。还有其他地方有记录吗?我猜它可能是稳定的,因为列表上的 sort 方法保证是稳定的(注意第 9 点:“从 Python 2.3 开始,sort() 方法保证是稳定的”),并且 sorted 在功能上是相似的。但是,我找不到任何确切的来源这么说。目的:我需要根据主键和辅助键进行排序...

问题描述:

文档没有保证这一点。还有其他地方有记录吗?

我猜它可能是稳定的,因为列表上的 sort 方法保证是稳定的(注意第 9 点:“从 Python 2.3 开始,sort() 方法保证是稳定的”),并且 sorted 在功能上是相似的。但是,我找不到任何确切的来源这么说。

目的:我需要根据主键和辅助键进行排序,以防两个记录的主键相等。如果 sorted() 保证稳定,我可以按辅助键排序,然后按主键排序并获得所需的结果。

PS:为了避免任何混淆,我使用稳定的意思是“如果排序保证不改变比较相等元素的相对顺序,那么它就是稳定的”。


解决方案 1:

是的,手册的目的确实是保证其sorted稳定性,并且确实使用与方法完全相同的算法sort。我确实意识到文档并没有 100% 清楚地说明这一身份;文档补丁总是被愉快地接受!

解决方案 2:

他们很稳定。

顺便说一句:有时,您可以通过将多遍排序与单遍排序相结合来忽略了解排序和已排序是否稳定。

例如,如果您想根据对象的last_name属性对其进行排序first_name,您可以一次性完成:

sorted_list= sorted(
    your_sequence_of_items,
    key= lambda item: (item.last_name, item.first_name))

利用元组比较。

这个答案按原样涵盖了原始问题。 有关进一步的排序相关问题,请参阅Python 排序方法。

解决方案 3:

在此期间,文档发生了变化(相关提交),并且当前文档sorted明确保证了这一点:

内置sorted()函数保证稳定。如果排序保证不改变比较相等的元素的相对顺序,则排序是稳定的 — 这有助于多次排序(例如,先按部门排序,然后按薪资等级排序)。

该部分文档已添加到 Python 2.7 和 Python 3.4(+),因此该语言版本的任何兼容实现都应该具有稳定的sorted

请注意,对于 CPython 来说,自Python 2.3list.sort以来一直很稳定

  • 蒂姆·彼得斯重写了他的list.sort()实现——这是一个“稳定排序”(相同的输入以相同的顺序出现在输出中)并且比以前更快。

我不能 100% 确定sorted,现在它只是简单地使用list.sort,但我没有检查过历史记录。但很可能它“总是”使用list.sort

解决方案 4:

Python 3.6 中关于排序的文档现在指出

排序保证稳定

此外,在该文档中,有一个指向稳定的Timsort的链接,其中指出

Timsort 自 2.3 版以来一直是 Python 的标准排序算法

解决方案 5:

Python 2.4 的“新功能”文档有效地指出 sorted() 首先创建一个列表,然后对其调用 sort(),为您提供所需的保证,尽管“官方”文档中没有提到。如果您真的担心,也可以查看源代码。

相关推荐
  政府信创国产化的10大政策解读一、信创国产化的背景与意义信创国产化,即信息技术应用创新国产化,是当前中国信息技术领域的一个重要发展方向。其核心在于通过自主研发和创新,实现信息技术应用的自主可控,减少对外部技术的依赖,并规避潜在的技术制裁和风险。随着全球信息技术竞争的加剧,以及某些国家对中国在科技领域的打压,信创国产化显...
工程项目管理   2757  
  为什么项目管理通常仍然耗时且低效?您是否还在反复更新电子表格、淹没在便利贴中并参加每周更新会议?这确实是耗费时间和精力。借助软件工具的帮助,您可以一目了然地全面了解您的项目。如今,国内外有足够多优秀的项目管理软件可以帮助您掌控每个项目。什么是项目管理软件?项目管理软件是广泛行业用于项目规划、资源分配和调度的软件。它使项...
项目管理软件   1693  
  在全球化的浪潮下,企业的业务范围不断拓展,跨文化协作变得愈发普遍。不同文化背景的团队成员在合作过程中,由于语言、价值观、工作习惯等方面的差异,往往会面临诸多沟通挑战。而产品生命周期管理(PLM)系统作为企业管理产品全生命周期的重要工具,如何有效支持跨文化协作成为了关键问题。通过合理运用沟通策略,PLM系统能够在跨文化团...
plm是什么软件   15  
  PLM(产品生命周期管理)系统在企业的产品研发、生产与管理过程中扮演着至关重要的角色,其中文档版本控制是确保产品数据准确性、完整性和可追溯性的关键环节。有效的文档版本控制能够避免因版本混乱导致的错误、重复工作以及沟通不畅等问题,提升企业整体的运营效率和产品质量。接下来,我们将深入探讨 PLM 系统实现文档版本控制的 6...
plm是什么意思   19  
  PLM(产品生命周期管理)项目管理旨在通过有效整合流程、数据和人员,优化产品从概念到退役的整个生命周期。在这个过程中,敏捷测试成为确保产品质量、加速交付的关键环节。敏捷测试强调快速反馈、持续改进以及与开发的紧密协作,对传统的测试流程提出了新的挑战与机遇。通过对测试流程的优化,能够更好地适应PLM项目的动态变化,提升产品...
plm管理系统   18  
热门文章
项目管理软件有哪些?
曾咪二维码

扫码咨询,免费领取项目管理大礼包!

云禅道AD
禅道项目管理软件

云端的项目管理软件

尊享禅道项目软件收费版功能

无需维护,随时随地协同办公

内置subversion和git源码管理

每天备份,随时转为私有部署

免费试用