数据结构实验之排序八:快速排序
Time Limit: 1000MS Memory Limit: 65536KB
Submit Statistic
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>
void qsort(int a[], int left, int right)
{
int x = a[left], i = left, j = right;
if (left >= right)
{
return ;
}
while (i < j)
{
while (i < j && a[j] >= x)
{
j--;
}
a[i] = a[j];
while (i < j && a[i] <= x)
{
i++;
}
a[j] = a[i];
}
a[i] = x;
qsort(a, left, i - 1);
qsort(a, i + 1, right);
}
int main()
{
int n, a[100010], i;
while (~scanf ("%d", &n))
{
for (i = 0; i < n; i++)
{
scanf ("%d", &a[i]);
}
qsort(a, 0, n - 1);
for (i = 0; i < n; i++)
{
printf ("%d%c", a[i], i < n - 1 ? ' ' : '\n');
}
}
return 0;
}