java基本算法之快速排序

快速排序:是找出一个元素(理论上可以随便找一个)作为基准(pivot),然后对数组进行分区操作,使基准左边元素的值都不大于基准值,基准右边的元素值 都不小于基准值,如此作为基准的元素调整到排序后的正确位置。递归快速排序,将其他n-1个元素也调整到排序后的正确位置。最后每个元素都是在排序后的正 确位置,排序完成。所以快速排序算法的核心算法是分区操作,即如何调整基准的位置以及调整返回基准的最终位置以便分治递归。

/**
* 快速排序
* 快速排序采用了分治策略。就是在一个数组中取一个基准数字,把小的数放基准的左边,大的数放基准的右边。
* 基准左边和右边分别是新的序列。在新的序列中再取一个基准数字,小的放左边,大的放右边。
* 这个里面用到的递归。我们需要三个参数,一个是数组,另外两个是序列的边界
* @author shaomch
*/
public class QuickSort {

public void quickSort(int[] arr, int left, int right) {
  if (left >= right) {
    return;
  }
  int i = left;
  int j = right;
  int piovt = arr[left];// 基准数:数组的第一个数作为基准数
  while (i != j) {
    // 循环1:从数组右边开始循环,直到找到小于基准数的元素并且放在数组的右边。
    while (i < j && arr[j] >= piovt) {
      j--;
    }
    arr[i] = arr[j];
    // 循环2:从数组左边开始循环,直到找到大于基准数的元素并且放在数组的左边。
    while (i < j && arr[i] <= piovt) {
      i++;
    }
    arr[j] = arr[i];
  }
  arr[i] = piovt;
  quickSort(arr, left, i - 1);
  quickSort(arr, i + 1, right);
}
}

原文地址:https://www.cnblogs.com/michaelShao/p/5607742.html