快排思想
通过一趟排序将序列分成左右两部分,其中左半部分的的值均比右半部分的值小,然后再分别对左右部分的记录进行排序,直到整个序列有序
代码及思路
public class Quick { //通过一趟排序将序列分成左右两部分,其中左半部分的的值均比右半部分的值小,
//然后再分别对左右部分的记录进行排序,直到整个序列有序
public static void main(String[] args){
int[] arr = {6,3,7,9,5,1,4};
quickSort(arr,0,arr.length-1);
//输出排序好的数组
System.out.println(Arrays.toString(arr));
}
public static void quickSort(int[] arr,int left,int right){
if(left > right){
return;
}
//定义变量保存基准数
int base = arr[left];
//定义变量i,指向最左边
int i = left;
//定义变量i,指向最右边
int j = right;
//当i和j不相遇的时候,在循环中进行检索
while (i != j){
//向由j从右往左检索比基准数小的,如果检索到比基准数小的就停下
//如果检索大于等于基准数就继续检索
while (arr[j] >= base && i < j){
j--;//j从右往左移动
}
//i从左往右检索
while (arr[i] <= base && i < j){
i++;//i从左往右移动
}
//代码走到这里,i停下了,j也停下了,然后交换i和j位置上的元素
int temp = arr[i];
arr[i] = arr[j];
arr[j] = temp;
}
//如果上面while循环的条件不成立,会跳出这个循环,往下执行,
//如果这个条件不成立说明i和j相遇了
//如果i和j相遇了,就交换基准数这个元素和相遇位置的元素
//把相遇位置的元素赋值给基准数这个位置的元素
arr[left] = arr[i];
//把基准数赋值给相遇位置的元素
arr[i] = base;
//基准数在这里就归位了,左边的数字都比他小,右边的都比他大
//排基准数的左边
quickSort(arr,left,i-1);
//排右边
quickSort(arr,j+1,right);
}
}