#include<stdio.h>
#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;
#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;
}
不足之处大家共同讨论和指出,谢了