给定n个元素组成的序列,利用递归与分治策略对其进行排序。
输入:
第1行:元素个数n
第2行:n个元素值
输出:
排好序的n个元素,元素之间用空格分开。
实例:
输入:
5 //输入元素个数
220 10 30 50 40 //输入5个元素
输出:
10 30 40 50 220 //输出排好序的5个元素
#include <iostream>
/* run this program using the console pauser or add your own getch, system("pause") or input loop */
void swap(int a,int b)
{
int t=a;
a=b;
b=t;
}
int Partition(int a[],int p,int r)
{
int i=p,j=r+1;
int x=a[p];
while(1)
{
while(a[++i]<x&&i<r);
while(a[--j]>x&&j>p);
if(i>=j)break;
int tmp=a[i];
a[i]=a[j];a[j]=tmp;
}
a[p]=a[j];
a[j]=x;
return j;
}
void quicksort(int a[],int p,int r)
{
if(p<r)
{
int q=Partition(a,p,r);
quicksort(a,p,q-1);
quicksort(a,q+1,r);
}
}
void printarr(int a[],int n)
{
for(int i=1;i<=n;i++)
std::cout<<a[i]<<" ";
}
int main(int argc, char** argv) {
int n;
std::cin>>n;
int a[n+1];
for(int i=1;i<=n;i++)
{
std::cin>>a[i];
}
quicksort(a,1,n);
printarr(a,n);
return 0;
}
合并排序问题的递归分治实现
2947

被折叠的 条评论
为什么被折叠?



