快速排序算法C語言

#include
#include<stdlib.h>
void change(int *a, int *b)
{
int temp = *a;
*a = *b;
*b = temp;
}
void quitesort(int *a, int left, int right)
{
int i = left;
int j = right;
if (i < j)
{
do
{
do
{
i++;
} while (a[i]<a[left] && i <right);//找到第一個比他大的數
do
{
j--;
} while (a[j]>a[left] && j > left);//找到第一個比他小的數
if (i < j)
{
change(&a[i], &a[j]);
}
} while (i<j);


change(&a[left], &a[j]);


quitesort(a, left, j );
quitesort(a, j + 1, right);
}
}


int main(int argc, char *argv[])
{


int a[10] = { 15,52,6,48,32,95,269,451,74,126 };
quitesort(a, 0, 10);

for (int i = 0; i < 10; i++)
{
printf("%5d", a[i]);
}
printf("\n");
system("pause");
return 0;

}


不足之處大家共同討論和指出,謝了

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章