Description
用函数实现快速排序,并输出每次分区后排序的结果
输入格式
第一行:键盘输入待排序关键的个数n
第二行:输入n个待排序关键字,用空格分隔数据
输出格式
每行输出每趟排序的结果,数据之间用一个空格分隔
输入样例
10
5 4 8 0 9 3 2 6 7 1
输出样例
1 4 2 0 3 5 9 6 7 8
0 1 2 4 3 5 9 6 7 8
0 1 2 4 3 5 9 6 7 8
0 1 2 3 4 5 9 6 7 8
0 1 2 3 4 5 8 6 7 9
0 1 2 3 4 5 7 6 8 9
0 1 2 3 4 5 6 7 8 9
#include <iostream>
using namespace std;
int n;
void print_array(int a[],int n)
{
for(int i=0;i<n;i++)
{
cout<<a[i]<<" ";
}
cout<<endl;
}
int partition(int a[],int low,int high)
{
int key=a[low];
while(low<high)
{
while(low<high&&a[high]>=key)
{
high--;
}
a[low]=a[high];
while(low<high&&a[low]<=key)
{
low++;
}
a[high]=a[low];
}
a[low]=key;
print_array(a,n);
return low;
}
void Qsort(int a[],int low,int high)
{
if(low<high)
{
int keyloc=partition(a,low,high);
Qsort(a,low,keyloc-1);
Qsort(a,keyloc+1,high);
}
}
int main()
{
cin>>n;
int *a=(int*)malloc(sizeof(int)*n);
for(int i=0;i<n;i++)
{
cin>>a[i];
}
Qsort(a,0,n-1);
return 0;
}