首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >依赖于数据初始组织的排序算法

依赖于数据初始组织的排序算法
EN

Stack Overflow用户
提问于 2014-04-03 06:07:03
回答 3查看 103关注 0票数 0

我目前正在研究排序算法。我研究过快速排序算法依赖于数据的初始组织。如果对数组进行排序,则快速排序将变得更慢。是否还有其他类型的数据依赖于最初的数据组织?

EN

回答 3

Stack Overflow用户

回答已采纳

发布于 2014-04-03 06:14:24

当然了。插入排序将是具有降序排序输入的O(n):

代码语言:javascript
复制
define selection_sort (arr):
  out = []
  while not (arr.is_empty()):
      x = arr.pop()
      out = insert x out
  return out

因为每个insert调用都是O(1)。如果使用pop_last()而不是pop(),那么在排序的升序输入上它将是最快的(这假设pop()和/或pop_last()本身是O(1)本身)。

票数 0
EN

Stack Overflow用户

发布于 2014-04-03 06:50:53

所有快速排序算法都尽量减少比较和移动操作。最小化移动操作取决于初始元素排序。我假设您是指初始组织的初始元素排序。

此外,最快的现实世界算法利用参考地点,这也显示了依赖于初始排序。

如果您只感兴趣于一个显著减缓或加速排序的依赖项,例如,气泡排序将在一次传递排序数据时完成。

最后,许多排序算法的平均时间复杂度O(N log N),但最坏的情况复杂度O(N^2)。这意味着这些O(N^2)算法存在特定的输入(例如排序或反向排序),这些输入会引发不良的运行时行为。一些快速排序版本就是这些算法的例子。

票数 0
EN

Stack Overflow用户

发布于 2014-04-03 06:22:11

如果你要问的是“我是否应该担心我应该在一个案例的基础上选择哪种排序算法?”,除非你正在处理成千上万的运算,否则简单的回答是“不”。大多数情况下,快速排序将是很好的(使用计算的枢轴进行快速排序,比如Java)。

在一般情况下,快速排序已经足够了。

另一方面,如果您的系统总是以一致的初始排序方式期望源数据,而且每次都需要长的CPU时间和功率,那么您肯定会为这种角点情况找到正确的算法。

票数 -1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/22829163

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档