-
Notifications
You must be signed in to change notification settings - Fork 29
/
ThreeWayQuickSort.java
40 lines (37 loc) · 1.34 KB
/
ThreeWayQuickSort.java
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
package sort_problem;
/**
* 快排改进:
* 1、切换到插入排序:
* 因为快速排序在小数组中也会递归调用自己,对于小数组,插入排序比
* 快速排序的性能更好,因此在小数组中可以切换到插入排序。
*
* 2、三数取中:
* 最好的情况下是每次都能取数组的中位数作为切分元素,但是计算中位数
* 的代价很高。一种折中方法是取 3 个元素,并将大小居中的元素作为切分元素。
*
* 3、三向切分:
* 对于有大量重复元素的数组,可以将数组切分为三部分,分别对应小于、等于和大于切分元素。
* 三向切分快速排序对于有大量重复元素的随机数组可以在线性时间内完成排序。
*/
public class ThreeWayQuickSort<T extends Comparable<T>> extends QuickSort<T> {
// @Override
protected void sort(T[] nums, int l, int h) {
if (h <= l) {
return;
}
int lt = l, i = l + 1, gt = h;
T v = nums[l];
while (i <= gt) {
int cmp = nums[i].compareTo(v);
if (cmp < 0) {
swap(nums, lt++, i++);
} else if (cmp > 0) {
swap(nums, i, gt--);
} else {
i++;
}
}
sort(nums, l, lt - 1);
sort(nums, gt + 1, h);
}
}