http://book.douban.com/annotation/15154366/
Q: java.util.Arrays 中使用的 sort 采用的是什么算法?
 
A: java中Arrays.sort使用了两种排序方法,quick sort 和优化的 merge sort。
 
Q: 为什么采用两种排序算法?
 
A: quick sort 主要是对哪些基本类型数据(int, short, long, float, double等)排序, 而 merge sort 用于对对象类型进行排序。
 
Q: quick sort 在统计意义上效率比 merge sort 高,为何不都采用 quick sort ?
 
A: 概括的说,一个是稳定性,一个是移动次数。使用不同类型的排序算法主要是由于 quick sort 是不稳定的,而 merge sort 是 stable 的。这里的 stable 是指比较相等的数据在排序之后仍然按照排序之前的前后顺序排列(保序性)。对于基本数据类型,稳定性没有意义。而对于对象类型,稳定性是比较重要的,因为对象相等的判断可能只是判断关键属性,最好保持相等对象的非关键属性的顺序与排序前一直;另外一个原因是由于合并排序相对而言比较次数比快速排序少,移动(对象引用的移动)次数比快速排序多,而对于对象来说,比较一般比移动耗时。
 
merge sort
 
(1)最坏时间复杂度是 O(nlgn);
 
(2)平均时间复杂度是 O(nlgn);
 
(3)空间复杂度是 O(1)。
 
quick sort
 
(1)最坏时间复杂度是 O(n^2);
 
(2)平均时间复杂度是 O(nlgn);
 
(3)空间复杂度是 O(n)。
 
验证了一下 java.util.Arrays.sort(arrayName) 的时间复杂度,程序如下:
 
  1. /* constant variables */
  2. final int NUM = 10;
  3. final int OFFSET = 2;
  4. final int LOOP = 100000;
  5. /* arrays */
  6. int[][] array = new int[NUM][];
  7. long[] start = new long[NUM];
  8. long[] end = new long[NUM];
  9. long[] cost = new long[NUM];
  10. /* initialization */
  11. for (int i = 0; i < array.length; ++i) {
  12. array[i] = new int[1 << (i * OFFSET)];
  13. }
  14. for (int i = 0; i < array.length; ++i) {
  15. for (int j = 0; j < array[i].length; ++j) {
  16. array[i][j] = (int)(Math.random());
  17. }
  18. }
  19. /* sorting */
  20. for (int count = 0; count < LOOP; ++count) {
  21. for (int i = 0; i < array.length; ++i) {
  22. start[i] = System.currentTimeMillis();
  23. Arrays.sort(array[i]);
  24. end[i] = System.currentTimeMillis();
  25. cost[i] += end[i] - start[i];
  26. }
  27. }
  28. /* output */
  29. for (int i = 0; i < cost.length; ++i) {
  30. System.out.println(
  31. "n = " + array[i].length +
  32. ", time = " + cost[i] / 1000.0
  33. );
  34. }
 
对不同规模n的数组,分别进行10万次排序,统计10万次排序的总时间,结果如下:
 
n = 1, time = 0.013s
 
n = 4, time = 0.011s
 
n = 16, time = 0.029s
 
n = 64, time = 0.066s
 
n = 256, time = 0.198s
 
n = 1024, time = 0.797s
 
n = 4096, time = 3.005s
 
n = 16384, time = 12.101s
 
n = 65536, time = 48.101s
 
n = 262144, time = 192.174s
http://book.douban.com/annotation/15154366/

[Java] java.util.Arrays 中使用的 sort 采用的算法 (转)的更多相关文章

  1. 源码(09) -- java.util.Arrays

    java.util.Arrays 源码分析 ------------------------------------------------------------------------------ ...

  2. java:数组操作工具类 java.util.Arrays包 主要方法详解

    Arrays类位于Java.util包下,是一个对数组操作的工具类,现将Arrays类中的方法做一个总结(JDK版本:1.6.0_34).Arrays类中的方法可以分为八类: sort(对数组排序) ...

  3. JDK源码(1.7) -- java.util.Arrays

    java.util.Arrays 源码分析 ------------------------------------------------------------------------------ ...

  4. java 中java.util.Arrays类---常用函数记录

    java.util.Arrays主要是用来对数组进行操作的类,主要包括以下方法: 1.数组转化列表,得到固定大小的列表,Arrays.asList(...): public static <T& ...

  5. Java中数组操作 java.util.Arrays 类常用方法的使用

    任何一门编程语言,数组都是最重要和常用的数据结构之一,但不同的语言对数组的构造与处理是不尽相同的. Java中提供了java.util.Arrays 类能方便地操作数组,并且它提供的所有方法都是静态的 ...

  6. Java找N个数中最小的K个数,PriorityQueue和Arrays.sort()两种实现方法

    最近看到了 java.util.PriorityQueue.刚看到还没什么感觉,今天突然发现他可以用来找N个数中最小的K个数. 假设有如下 10 个整数. 5 2 0 1 4 8 6 9 7 3 怎么 ...

  7. java.util.Arrays的使用

    在Java.util包中有一个工具类Arrays类,封装了一些操作数组的方法.简单使用如下: package com.arrays.test; import java.util.Arrays; pub ...

  8. Java 数组基础,java.util.Arrays

    定义数组 方式1(推荐,更能表明数组类型) 方式2(同C语言) 方式3定义时直接初始化 数组运用基础 数组长度 equals() 数组元素不为基本数据类型时 二维数组 二维数组基础 变长的二维数组 j ...

  9. JDK1.8源码(四)——java.util.Arrays 类

    java.util.Arrays 类是 JDK 提供的一个工具类,用来处理数组的各种方法,而且每个方法基本上都是静态方法,能直接通过类名Arrays调用. 1.asList public static ...

随机推荐

  1. .net学习笔记---webconfig的读与写

    System.ConfigurationManager类用于对配置文件的读取.其具有的成员如下: 一.AppSettings AppSetting是最简单的配置节,读写非常简单. 名称 说明 AppS ...

  2. Asp.Net - 9.socket(聊天室)

    9.1 Socket相关概念 IP地址 每台联网的电脑都有一个唯一的IP地址. 长度32位,分为四段,每段8位,用十进制数字表示,每段范围 0 ~ 255 特殊IP:127.0.0.1 用户本地网卡测 ...

  3. HTML5学习之视频与音频(三)

    <!DOCTYPE html> <html xmlns="http://www.w3.org/1999/xhtml"> <head> <m ...

  4. 在Eclipse中自定义类似syso的快捷代码模板

    sysout/syso syserr/ syse 点击菜单栏的“Window”->“Preferences”,打开“Preferences”对话框.在Preferences”对话框中点击“Jav ...

  5. 【JAVA之泛型】

    一.引例. 1.引例. 假设现在有一个ArrayList的容器,如果不使用泛型约束,则可以向容器中加入各种类型的对象,但是如果取出来的时候只是用一种类型的转换则肯定会抛出ClassCastExcept ...

  6. HDU5115 Dire Wolf(区间DP)

    渐渐认识到区域赛更侧重的是思维及基本算法的灵活运用,而不是算法的量(仅个人见解),接下来要更多侧重思维训练了. 区间DP,dp[i][j]表示从i到j最终剩余第i 与第j只的最小伤害值,设置0与n+1 ...

  7. 攻城狮在路上(肆)How tomcat works(三) 连接器:Connector

     在介绍中提到,Catalina中有两个主要的模块:连接器和容器.本章中你将会写一个可以创建更好的请求和响应对象的连接器,用来改进第2章中的程序.一个符合Servlet 2.3和2.4规范的连接器必须 ...

  8. 攻城狮在路上(叁)Linux(二十五)--- linux内存交换空间(swap)的构建

    swap的功能是应付物理内存不足的状况,用硬盘来暂时放置内存中的信息. 对于一般主机,物理内存都差不多够用,所以也就不会用到swap,但是对于服务器而言,当遇到大量网络请求时或许就会用到. 当swap ...

  9. android 入门-android自定义控件

    第一种:继承View 实现自己的属性 <com.cc.imagewithmarkersample.MyView android:id="@+id/myviewid" andr ...

  10. windows7下安装php的imagick和imagemagick扩展教程

    这篇文章主要介绍了windows7下安装php的imagick和imagemagick扩展教程,同样也适应XP操作系统,Win8下就没测试过了,需要的朋友可以参考下 最近的PHP项目中,需要用到切图和 ...