数据结构实验之排序八:快速排序
Time Limit: 1000MS
Memory Limit: 65536KB
Problem Description
给定N(N≤10^5)个整数,要求用快速排序对数据进行升序排列,注意不得使用STL。
Input
连续输入多组数据,每组输入数据第一行给出正整数N(≤10^5),随后给出N个整数,数字间以空格分隔。
Output
输出排序后的结果,数字间以一个空格间隔,行末不得有多余空格。
Example Input
8 49 38 65 97 76 13 27 49
Example Output
13 27 38 49 49 65 76 97
Hint
Author
参考代码
#include<stdio.h>
int a[100000];
void sort(int l,int r)
{
int key = a[l];
int i = l, j = r;
int temp;
while( i < j )
{
while( i < j && key <= a[j] ) j--;
a[i] = a[j];
while( i < j && key >= a[i] ) i++;
a[j] = a[i];
}
a[i] = key;
if( l < r )
{
sort(i+1,r);
sort(l,i-1);
}
}
void Output(int n)
{
int i;
for( i = 0; i < n; i++ )
{
if( i == n - 1 )
printf("%d\n",a[i]);
else
printf("%d ",a[i]);
}
}
int main()
{
int n,i;
while(~scanf("%d",&n))
{
for( i = 0; i < n; i++ )
{
scanf("%d",a+i);
}
sort(0,n-1);
Output(n);
}
return 0;
}