排序算法(转)
1.快速排序
快速排序算法是冒泡排序的一种改进,快速排序也是通过逐渐消除待排序的无序序列中逆序元素来实现排序的
算法思想:
(1) 我们从待排序的记录序列中选取一个记录(通常第一个)作为基准元素(称为key)key=arr[left],然后设置两个变量,left指向数列的最左部,right指向数据的最右部。
(2) key首先与arr[right]进行比较,如果arr[right]
(3) 如果右边存在arr[right]
(4) 然后再移动right重复上述步骤
(5) 最后得到 {23 58 13 10 57 62} 65 {106 78 95 85},再对左子数列与右子数列进行同样的操作。最终得到一个有序的数列。
{23 58 13 10 57 62} 65 {106 78 95 85}
{10 13} 23 {58 57 62} 65 {85 78 95} 106
10 13 23 57 58 62 65 78 85 95 106
算法实现:
package com.atguigu.calculate;
import java.util.Arrays;
/**
* @program: game
* @description: 快速排序算法
* @author: Tangseng
* @create: 2019-05-29 15:56
**/
public class QuikSort {
public static void quickSort(int[] arr, int left, int right) {
int pivot;
if (left < right) {
pivot = partition(arr, left, right);
quickSort(arr, left, pivot - 1);
quickSort(arr, pivot + 1, right);
}
}
private static int partition(int[] arr, int left, int right) {
//数组的第一个作为中轴
int key = arr[left];
while (left < right) {
while (left < right && arr[right] >= key) {
right--;
}
//比中轴小的记录移到低端
arr[left] = arr[right];
while (left < right && arr[left] <= key) {
left++;
}
//比中轴大的记录移到高端
arr[right] = arr[left];
}
//中轴记录到尾
arr[right] = key;
//返回中轴的位置
return right;
}
public static void main(String[] args) {
int arr[] = {65, 58, 95, 10, 57, 62, 13, 106, 78,78, 23, 85};
System.out.println("排序前:" + Arrays.toString(arr));
quickSort(arr, 0, arr.length - 1);
System.out.println("排序后:" + Arrays.toString(arr));
}
}
还没有评论,来说两句吧...