步驟為:
1.從數列中挑出一個元素,稱為 "基準"(pivot);
2.重新排序數列,所有元素比基準值小的擺放在基準前面,所有元素比基準值大的擺在基準的後面(相同的數可以到任一邊)。在這個分區退出之後,該基準就處於數列的中間位置。這個稱為分區(partition)操作。
3.遞迴地(recursive)把小於基準值元素的子數列和大於基準值元素的子數列排序。
遞迴的最底部情形,是數列的大小是零或一,也就是永遠都已經被排序好了。雖然一直遞迴下去,但是這個演算法總會退出,因為在每次的迭代(iteration)中,它至少會把一個元素擺到它最後的位置去。
複製代碼 代碼如下:
#include<stdio.h>
#include<stdlib.h>
#include<time.h>
#define RANDOM(i) (rand()%i)
#define N 9 //設定數組長度
//分區操作
int Partition(int array[], int left, int right)
{
int i,j;
int temp;
j = left-1;
for (i=left; i<=right; i++)
{
if (array[i] <= array[right]) //以最後一個數組的值為基準
{
j++;
temp = array[j];
array[j] = array[i];
array[i] = temp;
}
}
return j;
}
//迭代運算
void QuikSort(int array[], int left, int right)
{
int pivot;
if (left < right)
{
pivot = Partition(array, left, right);
QuikSort(array, left, pivot-1);
QuikSort(array, pivot+1, right);
}
}
//樣本
int main()
{
int i = 0;
int a[N];
srand((int)time(0)); //設定隨機數種子
for (i=0; i<N; i++) //排序前
{
a[i] = RANDOM(100);
printf("%d\t", a[i]);
}
printf("\n\n");
QuikSort(a, 0, N-1);
for (i=0; i<N; i++) //排序後
{
printf("%d\t", a[i]);
}
}