c說話疾速排序算法示例代碼分享。本站提示廣大學習愛好者:(c說話疾速排序算法示例代碼分享)文章只能為提供參考,不一定能成為您想要的結果。以下是c說話疾速排序算法示例代碼分享正文
步調為:
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]);
}
}