int main()
{
int m,n,r,i,j,k,t;
printf("请分别输入两组升序数列的长度:");
scanf("%d,%d",&m,&n);
r=m+n,i=m,j=n;
int a[i],b[j],c[r];
printf("请输入第一组整数数据:");
scanf("%d",&a[i]);
printf("请输入第二组整数数据:");
scanf("%d",&b[j]);
for(k=0;k<m;k++)
{
c[k]=a[i];
i++;
for(k=m;k<m+n;k++)
{
c[k]=b[j];
j++;
for(k=0;k<m+n;k++)
for(r=0;r<m+n;r++)
{
if(c[r+1]<c[r])
{
t=c[r];
c[r]=c[r+1];
c[r+1]=t;
}
}
}
}
printf("%d",&c[r]);
return 0;
}
供参考:
#include<stdio.h>
#define N 20
int main()
{
int a[N],b[N],c[2*N],m,n,i,j,k;
printf("请分别输入两组升序数列的长度:");
scanf("%d,%d",&m,&n);
printf("请输入第一组 %d 个整数数据:",m);
for(i=0;i<m;i++)
scanf("%d",&a[i]);
printf("请输入第二组 %d 个整数数据:",n);
for(i=0;i<n;i++)
scanf("%d",&b[i]);
i = 0; j = 0; k = 0;
while(i < m && j < n)
{
if(a[i] >= b[j])
c[k++] = b[j++];
else
c[k++] = a[i++];
}
if(i == m)
{
while(k < m + n)
{
c[k++] = b[j++];
}
}
if(j == n)
{
while(k < m + n)
{
c[k++] = a[i++];
}
}
for(i=0;i < m+n;i++)
printf("%4d",c[i]);
return 0;
}
你现在已经得到合并的数组c
,可以使用排序算法比如选择排序
对数组c
进行排序。
具体可参考:选择排序算法_Hard Coder的博客-CSDN博客_选择排序算法
如有帮助,希望采纳一下