#include <stdio.h>
#include <stdlib.h>
void QuickSort(int num[],int low,int high)
{
if(low<high)
{
int i,j,k;
k=num[low];
i=low;
j=high;
while(i<j)
{
while(i<j&&num[j]>=k) //先从右向左,找比num【j】小的放在空位左边
{
j--;
}
if(i<j)
{
num[i++]=num[j];
}
while(i<j&&num[i]<=k)
{
i++;
}
if(i<j)
{
num[j--]=num[i];
}
}
num[i]=k;
QuickSort(num,low,i-1);
QuickSort(num,i+1,high);
}
}
int main()
{
int num[5]= {1,3,2,5,4};
QuickSort(num,0,4);
for(int i=0; i<5; i++)
{
printf("%d\n",num[i]);
}
return 0;
}
相关文章
- 01-29C语言基础-指针基础
- 01-29排序算法----调用库函数qsort进行快速排序
- 01-29C 语言之预处理 ---------文件包括
- 01-291353: 整存零取(C语言)
- 01-29寒假刷C语言题库的心得(大一)
- 01-29【计算机二级C语言】卷003
- 01-29浅析约瑟夫自杀环(C语言)
- 01-29【C语言细节】静态二维数组
- 01-29openCV练习代码(C语言版本)
- 01-29C语言函数指针