这个快速排序是快速排序的最初版本,是由C.A.R.Hoare设计的。
基本思路:
1.将待排序数据存入一维数组中,然后以第一个值为基准值。起初i指向第一个元素,j指向最后一个元素之后的位置。
2.分别从两端遍历数组,直到i所指向的值比基准值大,以及j所指向的值比基准值小时,分别停止遍历,然后交换i,j所指
向的值。
3.重复步骤2,直到i>=j,然后交换p和j所指向的值,此时序列别分隔成两部分,基准值右边的值都比基准值大,而左边
的元素都比基准值小。
4.分别对左右两部分重复1-4步骤,即可完成排序。(如下图)

/*
* 名称:快速排序
* 作者:Brooke gao
* 时间:2013/6/17
* 注:此算法来自《计算机算法设计与分析》王晓东 编
*
*/
#include <stdio.h>
#define SIZE 100
void swap(int *x, int *y)
{
int temp = *x;
*x = *y;
*y = temp;
}
int Partition(int *A, int p, int r)
{
int i, j, x;
i = p;
j = r + 1;
x = A[p];
while(1)
{
while(A[++i] < x);
while(A[--j] > x);
if(i >= j)
break;
swap(&A[i],&A[j]);
}
A[p] = A[j];
A[j] = x;
return j;
}
void QuickSort(int *A, int p, int r)
{
int q;
if(p < r)
{
q = Partition(A,p,r);
QuickSort(A,p,q-1);
QuickSort(A,q+1,r);
}
}
void PrintResult(int *A, int size)
{
int i;
for(i = 0; i < size; i++)
{
printf("%-2d",A[i]);
}
putchar('\n');
}
int main(void)
{
int A[SIZE], i, sum;
printf("输入要排序元素的个数(0-100): ");
scanf("%d",&sum);
printf("请输入%d个整数:\n",sum);
for(i = 0; i < sum; i++)
{
scanf("%d",&A[i]);
}
QuickSort(A,0,sum-1);
printf("排序结果:\n");
PrintResult(A,sum);
}