给定两组已按顺序排列好的整形数据,编写一个程序把他们合并为一组按顺序排列的数据。请问后面部分怎么改?

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博客_选择排序算法
如有帮助,希望采纳一下