算法思想:
快速排序是基于分治法的思想,是冒泡排序的改进型。快速排序由C. A. R. Hoare在1962年提出。它的基本思想是:通过一趟排序将要排序的数据分割成独立的两部分,其中一部分的所有数据都比另外一部分的所有数据都要小,然后再按此方法对这两部分数据分别进行快速排序,整个排序过程可以递归进行,以此达到整个数据变成有序序列。快速排序的平均时间复杂对为O(n×log(n)),最坏情况时间复杂度为O(n^2)。(后续了解详情)
代码实现:
package com.algorithm.test;
/**
* 快速排序练习
* @project 算法练习
* @author zhou
* @date 2017年12月18日
* @version 1.0.0
* Copyright(c) YIJIAN All Rights Reserved
*/
public class QuickSort {
/**
* 快速排序,从小到大
* @author zhou
* @param array 需要排序的数组
* @param low 前置数组下标
* @param high 后置数组下标
*/
public static int QuickSort(int[] array,int low,int high){
int flag = array[low];
while(low<high) {
while(array[high]>=flag&&high>low) {
high--;
}
array[low] = array[high];
while(array[low]<=flag&&high>low) {
low++;
}
array[high] = array[low];
}
array[high]=flag;
return high;
}
public static void Sort(int[] array,int low,int high){
if(low>=high){
return ;
}
int index=QuickSort(array,low,high);
Sort(array,low,index-1);
Sort(array,index+1,high);
}
public static void main(String[] args){
int array[] = {1,54,6,3,78,34,12,45};
int low = 0;
int i = 0;
int high = array.length-1;
Sort(array,low,high);
while(i<array.length-1) {
System.out.print(array[i]+"、");
i++;
}
}
}
2017年12月18日陕西易唐云网智能科技有限公司