3047: 快速排序算法
提交: 676 | 解决: 66 | 时间限制: 1.00s | 内存限制: 128MB
题目描述
设计一个程序,实现快速排序算法,并输出 {6,8,7,9,0,1,3,2,4,5}\{6,8,7,9,0,1,3,2,4,5\}{6,8,7,9,0,1,3,2,4,5} 的排序过程。
输出
每个排序过程输出一行,直到排序完成。
样例输出复制
6,8,7,9,0,1,3,2,4,5
...
...
#include<stdio.h>
int arr[10]={6,8,7,9,0,1,3,2,4,5};
void quickSort(int *arr,int begin,int end)
{
//如果区间不只一个数
if(begin < end)
{
int temp = arr[begin]; //将区间的第一个数作为基准数
int i = begin; //从左到右进行查找时的“指针”,指示当前左位置
int j = end; //从右到左进行查找时的“指针”,指示当前右位置
//不重复遍历
while(i<j)
{
//当右边的数大于基准数时,略过,继续向左查找
while(i<j&&arr[j]>temp)
j--;
//不满足条件时跳出循环,此时的j对应的元素是小于基准元素的
//将右边小于等于基准元素的数填入左边相应位置
//当左边的数小于等于基准数时,略过,继续向右查找
if(i<j)
arr[i]=arr[j];
//不满足条件时跳出循环,此时的i对应的元素是大于等于基准元素的
//将左边大于基准元素的数填入右边相应位置
while(i<j&&arr[i]<temp)
i++;
//将基准元素填入相应位置
if(i<j)
arr[j]=arr[i];
}
//此时的i即为基准元素的位置
arr[i]=temp;
print(arr);
//对基准元素的左边子区间进行相似的快速排序
quickSort(arr,begin,i-1);
//对基准元素的右边子区间进行相似的快速排序
quickSort(arr,i+1,end);
}
//如果区间只有一个数,则返回
else
return;
}
void print(int *arr)
{
int i;
for(i=0;i<10;i++)
{
printf("%d",arr[i]);
if(i!=9)
printf(",");
}
printf("\n");
return;
}
int main()
{
print(arr);
quickSort(arr,0,9);
return 0;
}