快速排序笔记

算法思想:
基于分治的思想,是冒泡排序的改进型。首先在数组中选择一个基准点(该基准点的选取可能影响快速排序的效率,后面讲解选取的方法),然后分别从数组的两端扫描数组,设两个指示标志(lo指向起始位置,hi指向末尾),首先从后半部分开始,如果发现有元素比该基准点的值小,就交换lo和hi位置的值,然后从前半部分开始扫秒,发现有元素大于基准点的值,就交换lo和hi位置的值,如此往复循环,直到lo>=hi,然后把基准点的值放到hi这个位置。一次排序就完成了。以后采用递归的方式分别对前半部分和后半部分排序,当前半部分和后半部分均有序时该数组就自然有序了。


代码:

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
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
import java.util.HashMap;
import java.util.HashSet;
import java.util.Random;
import java.util.Set;

public class QuickSort {
public static void main(String[] args) {
//自定义int数组
//int[] array = {6,3,7,4,1};
//{15,7,10,8,16};
//{6,3,7,4,1}

// //随机产生int数组
// Random r = new Random(System.currentTimeMillis());
// int[] array = new int[10];
// int i = 0;
// while (i < 10) {
// array[i++] = r.nextInt(20);
// }

//随机产生不重复的随机数组
HashSet<Integer> set = new HashSet<>();
randomSet(10, 40, 10, set);
int[] array = new int[10];
int i = 0;
for (int y : set) {
array[i++] = y;
}

System.out.println("排序前的数组:");
printArray(array);

quickSort(array, 0, array.length - 1);

System.out.println("排序后的数组:");
printArray(array);
}

private static int partition(int[] array, int low, int high) {
int key = array[low];
while (low < high) {
//先从右往左
while (array[high] >= key && low < high) {
high--;
}
swap(array, low, high);
//再从左往右
while (array[low] <= key && low < high) {
low++;
}
swap(array, low, high);
}
//array[low] = key;//array[high] = key;
return low;//return high;
}

private static void quickSort(int[] array, int low, int high) {
if (low >= high) return;
int index = partition(array, low, high);
quickSort(array, low, index - 1);
quickSort(array, index + 1, high);
}

private static void swap(int[] nums, int i, int j) {
int t = nums[i];
nums[i] = nums[j];
nums[j] = t;
}

private static void printArray(int[] array) {
for (int x : array)
System.out.print(x + " ");
System.out.println();
}

private static void randomSet(int min, int max, int n, HashSet<Integer> set) {
if (n > (max - min + 1) || max < min) return;
for (int i = 0; i < n; i++) {
//int num = (int) (Math.random() * (max - min)) + min;
int num = new Random().nextInt(max - min) + min ;
set.add(num);
}
int setSize = set.size();
if (setSize < n)
randomSet(min, max, n - setSize, set);
}
}

参考网站:
快速排序和基准点的三数取中