排序算法总结

学习了这么多的排序算法,还没有做个总结,呵呵

 

      冒泡排序

冒泡排序是最慢的排序算法。在实际运用中它是效率最低的算法。它通过一趟又一趟地比较数组中的每一个元素,使较大的数据下沉,较小的数据上升。它是O(n^2)的算法。

  快速排序

快速排序是一个就地排序,分而治之,大规模递归的算法。从本质上来说,它是归并排序的就地版本。快速排序可以由下面四步组成。

1 如果不多于1个数据,直接返回。
2 一般选择序列最左边的值作为支点数据。
3 将序列分成2部分,一部分都大于支点数据,另外一部分都小于支点数据。
4 对两边利用递归排序数列。

快速排序比大部分排序算法都要快。尽管我们可以在某些特殊的情况下写出比快速排序快的算法,但是就通常情况而言,没有比它更快的了。快速排序是递归的,对于内存非常有限的机器来说,它不是一个好的选择。
 
  归并排序

归并排序先分解要排序的序列,从1分成22分成4,依次分解,当分解到只有1个一组的时候,就可以排序这些分组,然后依次合并回原来的序列中,这样就可以排序所有数据。合并排序比堆排序稍微快一点,但是需要比堆排序多一倍的内存空间,因为它需要一个额外的数组。
 
   堆排序

堆排序适合于数据量非常大的场合(百万数据)。

堆排序不需要大量的递归或者多维的暂存数组。这对于数据量非常巨大的序列是合适的。比如超过数百万条记录,因为快速排序,归并排序都使用递归来设计算法,在数据量非常大的时候,可能会发生堆栈溢出错误。

堆排序会将所有的数据建成一个堆,最大的数据在堆顶,然后将堆顶数据和序列的最后一个数据交换。接下来再次重建堆,交换数据,依次下去,就可以排序所有的数据。
 
   希尔排序

Shell
排序通过将数据分成不同的组,先对每一组进行排序,然后再对所有的元素进行一次插入排序,以减少数据交换和移动的次数。平均效率是O(nlogn)。其中分组的合理性会对算法产生重要的影响。现在多用D.E.Knuth的分组方法。

Shell
排序比冒泡排序快

  • 0
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Pareto排序算法是一种用于多目标优化问题的排序方法,它可以将解集中的解按照非支配关系进行排序。在Pareto排序算法中,首先需要确定一个基准解,然后将其他解与基准解进行比较,根据非支配关系将解分为不同的层次。具体的排序方法有很多种,包括庄家法、擂台赛法、递归方法以及快速排序方法等\[2\]。 快速排序方法是目前普遍使用的Pareto排序算法之一。它通过将解集划分为两个子集,然后对每个子集进行递归排序,最终将解集按照非支配关系进行排序。在快速排序方法中,首先选择一个解作为基准解,然后将其他解与基准解进行比较,将非支配的解放入一个新的集合中。接下来,对新集合进行递归排序,直到所有解都被排序为止\[2\]。 通过多轮排序,Pareto最优解集可以被找到。在排序的过程中,解集中的解按照非支配关系被分为不同的层次。最终,我们可以得到一个非支配层次关系的种群个体集合\[3\]。 总结来说,Pareto排序算法是一种用于多目标优化问题的排序方法,它可以将解集按照非支配关系进行排序。其中,快速排序方法是一种常用的Pareto排序算法,通过递归地将解集划分为子集并进行排序,最终得到Pareto最优解集\[2\]\[3\]。 #### 引用[.reference_title] - *1* *2* *3* [多目标进化算法(二)——非支配排序/NSGA-II](https://blog.csdn.net/qq_38537501/article/details/123360414)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^control,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值