1、快速排序:,又称划分交换排序(partition-exchange sort),简称快排,一种排序算法,最早由东尼·霍尔提出。在平均状况下,排序n个项目要O(n log2 n)(大O符号)次比较。在最坏状况下则需要 O(n^2)次比较,但这种状况并不常见。事实上,快速排序 (n log n)通常明显比其他算法更快,因为它的内部循环(inner loop)可以在大部分的架构上很有效率地达成。——(维基百科)
2、快序排序:(1)是一种多次划分操作实现排序。
(2)每一趟选择当前所有子序列中的一个关键字(通常是第一个)作为枢轴,将子序列中比枢轴小的移到枢轴的前边, 比枢轴大的移到枢轴的后面;当本趟所有子序列都被枢轴以上述规则划分完成后会得到新的一组更短子序列,他们成为下一趟划分的初始序列集(快速排序是递归进行,需要栈的辅助,因此她需要的辅助空间比较大)
3、代码
void QuickSort(int arr[],int low, int high){
int temp;
int i=low,j=high;
if(low<high){
temp=arr[low];
while(i<j){
while(i<j&&arr[j]>=temp) --j;
if(i<j){
arr[i]=arr[j];
++i;
}
while(i<j&&arr[i]<temp) ++i;
if(i<j){
arr[j]=arr[i];
--j;
}
}
arr[i]=temp;
QuickSort(arr,low,i-1);//递归对temp左边的关键字排序
QuickSort(arr,i+1,high);//递归对temp后边的关键字排序
}
}