出于某种原因,测了一下Sun的JDK的qsort,也即Arrays.sort,虽然源码注释中说道:
//The sorting algorithm is a tuned quicksort
但结果出乎意料,对int数组进行排序,性能几乎是线性的,到底是为啥么捏?难道是Java
代码如下:
import java.util.Arrays;
public class SortTest {
public static void main(String[] args) {
for (int i = 10000000; i < 1000000000; i += 10000000) {
sort(i);
}
}
private static void sort(int i) {
int n[] = new int[i];
for (int j = 0; j < n.length; j++) {
n[j] = (int) (Math.random() * Integer.MAX_VALUE);
}
long s = System.currentTimeMillis();
Arrays.sort(n);
long e = System.currentTimeMillis();
System.out.print(i + "\t\t");
System.out.println(e - s);
}
}
结果如下:可以看出,基本上是线性的。环境:WinXP SP3,JDK1.6.0_13,E8400,4G内存,javac SortTest.java,java -Xmx1024m SortTest
10000000 1610
20000000 3328
30000000 5187
40000000 7031
50000000 8766
60000000 10625
70000000 12578
80000000 14500
90000000 16359
100000000 18250
分享到:
相关推荐
本主题将深入探讨四种常见的排序算法:堆排序、快速排序以及两种未在标题中明确提到但同样重要的排序方法——基数排序和计数排序。 首先,让我们详细了解一下堆排序。堆排序是一种基于比较的排序算法,利用了数据...
- **影视广告制作**:利用非线性编辑技术可以快速制作出高质量的影视广告。 - **教学资料片制作**:教师可以使用非线性编辑软件制作互动性强的教学视频。 - **企业宣传片**:企业利用非线性编辑技术制作出富有创意的...
其核心思想是将输入数据分发到有限数量的桶中,然后对每个桶分别排序(通常使用快速排序),最后再将桶中的数据按顺序连接起来。 1. **初始化桶**:创建一系列空的桶。 2. **分配元素到桶**:遍历输入数据,将每个...
本文将详细讲解六种经典的排序算法——合并排序、插入排序、希尔排序、快速排序、冒泡排序以及桶排序,并结合提供的文件名(sort.c、set.c、main.c、set.h、sort.h)推测出每个文件可能包含的代码实现。 1. **合并...
对于大数据集,更高效的排序算法如快速排序、归并排序或堆排序更为合适。 下面是C++实现线性选择排序的一个基本示例: ```cpp #include #include using namespace std; void selectionSort(vector<int>& arr) ...
本主题将深入探讨四种常见的排序算法:归并排序、快速排序以及与链表相关的排序方法。 首先,我们来讨论归并排序(Merge Sort)。这是一种基于分治策略的排序算法。归并排序将大问题分解为小问题,然后逐步合并这些...
位排序和快速排序是两种不同的排序算法,它们在处理大量数据时各有特点。在这个场景中,我们关注的是如何使用这两种算法来对30万个由程序生成的数字进行排序。 首先,我们来了解一下位排序(Bitonic Sort)。位排序...
在现代计算机科学中,快速排序是一种被广泛使用的排序算法,其核心思想基于分治法,即通过递归方式将问题分解为规模更小的子问题。本文旨在深入探究快速排序的串行和并行实现,并对并行快速排序算法在实验环境下的...
与基于比较的排序算法(如快速排序和归并排序)相比,线性排序算法不依赖于元素间的比较,而是利用数据的具体特征来进行排序,因此能够达到更高的效率。 ##### 1. 桶排序(Bucket Sort) 桶排序的基本思想是将待...
这里有8种常见的排序算法,包括选择排序、冒泡排序和快速排序等。这些算法各有特点,适用于不同的场景,理解并掌握它们对于编程和数据处理至关重要。 1. **选择排序(Selection Sort)** 选择排序是一种简单直观的...
快速排序是一种高效的排序算法,由英国计算机科学家C.A.R. Hoare在1960年提出。它的基本思想是分治策略,通过一趟排序将待排序的数据分割成独立的两部分,其中一部分的所有数据都比另一部分的所有数据都要小,然后再...
在处理几百万甚至几千万级别的数据时,快速排序能够提供比其他线性时间复杂度的排序算法更高的性能。 去重则是另一个关键步骤,特别是在处理大量文本数据时,确保数据唯一性是非常重要的。常见的去重方法有哈希表、...
然而,由于快速排序通常在实际应用中表现得比归并排序更快,特别是在小规模和内存在线性空间的排序中。 在C++中,实现这两种排序算法可以使用STL中的`std::sort`函数,但它内部实现可能不是归并排序或快速排序,...
常见的排序算法有桶排序、冒泡排序和快速排序,每种排序方法都有其特定的使用场景和优缺点。 桶排序(Bucket Sort)是一种分布式排序算法,它将一个数组分成多个“桶”,然后将数组中的每个元素放入对应的桶中。桶...
本资源包"选择排序 冒泡排序 插入排序 快速排序 堆排序.zip"聚焦于五种经典的排序算法,包括选择排序、冒泡排序、插入排序、快速排序以及堆排序。这些算法的实现语言是Objective-C,这是一种强大的面向对象的编程...
3. **快速排序**(Quick Sort):快速排序是一种高效的排序算法,采用“分而治之”的策略。它选取一个基准元素,将数组分为两部分,一部分的所有元素都小于基准,另一部分所有元素都大于基准,然后递归地对这两部分...
快速排序的时间复杂度为O(nlogn),这是因为每次递归划分都使得问题规模缩小至原来的1/2,同时进行一次线性扫描。 然而,JDK7以后的Java开发工具包中内置的排序算法已经不再是传统意义上的快速排序,而是被Dual-...
这里我们汇总了七种常见的排序算法:Shell排序、归并排序、选择排序、快速排序、堆排序、冒泡排序和插入排序。每种算法都有其独特的特点和适用场景,下面将逐一详细介绍。 1. **Shell排序**:由Donald Shell提出,...
以下是关于四种经典排序算法——插入排序、冒泡排序、快速排序和选择排序的详细解释,以及它们在多线程环境下的应用考虑。 1. **插入排序**:插入排序是一种简单直观的排序算法,它的工作原理类似于人们玩扑克牌时...