排序分析

各算法的时间复杂度
  平均时间复杂度
  插入排序 O(n^2)
  冒泡排序 O(n^2)
  选择排序 O(n^2)
  快速排序 O(n log n)
  堆排序 O(n log n)
  归并排序 O(n log n)
  基数排序 O(n)
  希尔排序 O(n^1.25)

1 快速排序(QuickSort)

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

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

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

2 归并排序(MergeSort)

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

3 堆排序(HeapSort)

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

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

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

4 Shell排序(ShellSort)

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

Shell排序比冒泡排序快5倍,比插入排序大致快2倍。Shell排序比起QuickSort,MergeSort,HeapSort慢很多。但是它相对比较简单,它适合于数据量在5000以下并且速度并不是特别重要的场合。它对于数据量较小的数列重复排序是非常好的。

5 插入排序(InsertSort)

插入排序通过把序列中的值插入一个已经排序好的序列中,直到该序列的结束。插入排序是对冒泡排序的改进。它比冒泡排序快2倍。一般不用在数据大于1000的场合下使用插入排序,或者重复排序超过200数据项的序列。

6 冒泡排序(BubbleSort)

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

7 交换排序(ExchangeSort)和选择排序(SelectSort)

这两种排序方法都是交换方法的排序算法,效率都是 O(n2)。在实际应用中处于和冒泡排序基本相同的地位。它们只是排序算法发展的初级阶段,在实际中使用较少。

8 基数排序(RadixSort)

基数排序和通常的排序算法并不走同样的路线。它是一种比较新颖的算法,但是它只能用于整数的排序,如果我们要把同样的办法运用到浮点数上,我们必须了解浮点数的存储格式,并通过特殊的方式将浮点数映射到整数上,然后再映射回去,这是非常麻烦的事情,因此,它的使用同样也不多。而且,最重要的是,这样算法也需要较多的存储空间。

时间: 2024-12-10 09:54:26

排序分析的相关文章

待字闺中之巧妙排序分析:

题目来源.待字闺中.原创@陈利人 ,欢迎大家继续关注微信公众账号"待字闺中" 排序仅仅有1.2,3三个元素的数组.不能统计1,2.3的个数. 分析:这个题目,虽然也是排序,但却不能使用高速排序的方法.仅仅有三个元素,假设时间复杂度仍旧是O(nlogn).显然不是最好的.那就行使用线性的排序算法,比如计数排序.但是题目中要求,不可以对1,2,3进行统计个数.那该怎样处理呢?请大家看以下的方法,我们首先通过样例来说明: 2 1 1 3 3 2 p1 p2       p3 如果,我们有三个

jquery -- 拖拽排序分析

今天应一个朋友的委托,研究一下拖拽排序,我记得我上次写拖拽排序,因为方法太死板,效果我一直不是很满意,一直想再从写一个,一直没机会(懒),这次因为公司部门变动所以有了一些时间(无聊)来写,本来准备使用Vue写,奈何功夫不到家在自定义指令的时候,问题卡住了,研究了一段时间之后,还是决定放弃,研究一下Vue再来写过,所以本次还是用了Jquery来写. 直接上代码 这是CSS部分 1 *{/*Css*/ 2 margin: 0px; 3 padding: 0px; 4 list-style: none

股票分析之主力资金排序分析

主力资金在个股上的反应更为明显,个股主力资金进入的多,则股票上涨的概率较大,工具中的菜单位置: 资金流入净占比排序,在该列表中,可根据一日.五日和十日进行排序:   我们可以根据主力净流入资金进行排序:

Comparable和Comparator比较实现排序 场景分析

源码分析 - Collections.sort() 一.Collection.sort使用 Collections.sort():是对一个集合进行正向排序的方法首先,传入Collections.sort()的集合的元素类型要继承Comparator<T>,这样才能保证可以比较并排序. 根据源码分析,实现方式主要有两种: (1)对普通类型和String等类型排序 (2)对JavaBean某个属性(比如时间,价格,年龄排序)进行排序 使用案例: List<String> listOne

常见排序的JAVA实现

还有好多其他排序而且每种排序都有优化,之后会不断添加. /** * 文件名:SortTest.java * 时间:2014年11月5日下午6:05:13 * 作者:修维康 */ package chapter7; import java.util.Arrays; /** * 类名:SortTest 说明:各类排序分析详解 */ public class SortTest { /** * 方法名:insertionSort 说明:插入排序 时间复杂度O(N^2) */ public static

智能评论排序

我们在网上购物或者逛一些论坛.社区时往往都会发现购物时会参考其他用户是如何评价这个商品的.逛社区,如知乎之类时我们看一些东西往往只会看排在前几个的答案,而基本会忽略掉后面众多的答案.除非你是瞎混时间,如玩豆瓣,一层层楼扒,不落下任何词句. 然而,很多购物网站.社区各自评论排列是不一样的规则,有的仅仅按照评论.答案更新时间排序,或者因为各自规则不同而导致我们会错过一些对我们决策的有用信息.就拿购物来说,可能最终会影响到我们是否下单,下单转化率降低,用户体验不佳. 那么,我们可以如何让有效的,优秀的

排序算法总结之希尔排序

一,希尔排序算法介绍 ①希尔排序又称缩小增量排序 ,它本质上是一个插入排序算法.为什么呢? 因为,对于插入排序而言,插入排序是将当前待排序的元素与前面所有的元素比较,而希尔排序是将当前元素与前面增量位置上的元素进行比较,然后,再将该元素插入到合适位置.当一趟希尔排序完成后,处于增量位置上的元素是有序的. ②希尔排序算法的效率依赖于增量的选取 假设增量序列为 h(1),h(2).....h(k),其中h(1)必须为1,且h(1)<h(2)<...h(k) . 第一趟排序时在增量为h(k)的各个元

综合案例分析(sort,cut,正则)

1.    找出ifconfig "网卡名" 命令结果中本机IPv4地址 分析: 解释:要取出ip地址,首先我们可以先取出ip所在的行,即取行:可以结合head和tail,后面会有 更好的方法去取行,取列当然会想到cut命令,但是此例中,我们要考虑分隔符(空格和冒号), 因此tr的引入,会使题目变得更加简单. 答: 在这里小编仅提供一种比较好的方法. 2.查出分区空间使用率的最大百分比值 分析: 解释;先附上一张df查看的结果,比较容易解释 首先我们可以用df查看分区,很明显我们需要的

代码实现:模拟斗地主洗牌和发牌,牌没有排序

package com.loaderman.test; import java.util.ArrayList; import java.util.Collections; public class Test { /** * * A:案例演示 * 模拟斗地主洗牌和发牌,牌没有排序 * * 分析: * 1,买一副扑克,其实就是自己创建一个集合对象,将扑克牌存储进去 * 2,洗牌 * 3,发牌 * 4,看牌 */ public static void main(String[] args) { //1