【问题描述】使用递归合并排序算法对若干整数进行排序。说明:在数组a的编号[left, right]范围内求取中间元素编号mid时,mid=floor((left+right)/2)。
【输入形式】在屏幕上输入若干整数,各数间都以一个空格分隔。
【输出形式】输出递归函数MergeSort调用的次数和最终从小到大排序好的结果。
【样例输入】
48 38 65 97 76 13 27
【样例输出】
13
13 27 38 48 65 76 97
【样例说明】
输入:7个整数,以空格分隔。
输出:第一行输出递归函数MergeSort调用的次数,第二行输出最终从小到大排序好的结果,整数间以一个空格分隔。
【评分标准】根据输入得到准确的输出
代码实现
#include<iostream>
#include<sstream>
using namespace std;
#define N 100
int b[100];
int sums=0;
void Merge(int c[],int d[],int l,int m,int r)
{
int i=l,j=m+1,k=l;
while((i<=m)&&(j<=r))
{
if(c[i]<=c[j])
{
d[k++]=c[i++];
}
else
{
d[k++]=c[j++];
}
}
if(i>m)
{
for(int q=j;q<=r;q++)
{
d[k++]=c[q];
}
}
else
{
for(int q=i;q<=m;q++)
{
d[k++]=c[q];
}
}
}
void Copy(int a[],int b[],int left,int right)
{
for(int i=left;i<=right;i++)
{
a[i]=b[i];
}
}
void MergeSort(int a[],int left,int right)
{
sums++;
if(left<right)
{
int mid=(left+right)/2;
MergeSort(a,left,mid);
MergeSort(a,mid+1,right);
Merge(a,b,left,mid,right);
Copy(a,b,left,right);
}
}
int main()
{
int a[N];
int number,n=0;
string s;
getline(cin,s);
stringstream ss(s);
while (ss>>number)
{
a[n++]=number;
}
MergeSort(a,0,n-1);
cout<<sums<<endl;
for(int i=0;i<n;i++)
{
cout<<a[i]<<' ';
}
}