洛谷 P1177 【模板】快速排序
题目描述
利用快速排序算法将读入的N个数从小到大排序后输出。
输入输出格式
输入格式:
第1行为一个正整数N,第2行包含N个空格隔开的正整数a_i
输出格式:
将给定的N个数从小到大输出,数之间空格隔开,行末换行且无空格。
输入输出样例
输入样例#1:
5
4 2 4 5 1
输出样例#1:
1 2 4 4 5
说明
对于20%的数据,有N≤1000;
对于100%的数据,有N≤100000。
#include <bits/stdc++.h>
using namespace std;
int a[100005];
void quick_sort(int x,int y)
{
int i=x,j=y;
int k=a[x];
if(i>=j)
return;
while(i<j)
{
while(i<j&&a[j]>k)
j--;
if(i<j)
{
a[i]=a[j];
i++;
}
while(i<j&&a[i]<=k)
i++;
if(i<j)
{
a[j]=a[i];
j--;
}
}
a[i]=k;
quick_sort(x,i-1);
quick_sort(i+1,y);
}
int main()
{
int n;
scanf("%d",&n);
for(int i=0; i<n; i++)
scanf("%d",&a[i]);
quick_sort(0,n-1);
for(int i=0; i<n; i++)
{
printf("%d ",a[i]);
}
return 0;
}