如何用C语言编程将两个有序数组a,b合并成一个数组c

例如:a={1,5,9},b={3,7,8},则c={1,3,5,7,8,9}... 例如:a={1,5,9},b={3,7,8},则c={1,3,5,7,8,9} 展开
 我来答
闪闪的红星lm
2013-04-15
知道答主
回答量:30
采纳率:0%
帮助的人:21.7万
展开全部
就以你的例子来写,可适当修改为更普遍的

算法核心代码为:

int i = j = k = 0;
//循环比较,将小的插入到C数组中

while ( i < 3 && j < 3) {
if (a [i] < b [j]) c[k++] = a[i++];
else c[k++] = b[j++];

}
//处理其中一个数组剩下

while (i < 3) c[k++] = a[i++];
while( j < 3) c[k++] = b[j++];
或许有更好的实现,你自己在想想吧!
追问
谢谢!
kexuan0806
推荐于2017-09-26 · TA获得超过803个赞
知道小有建树答主
回答量:844
采纳率:0%
帮助的人:363万
展开全部
#include<stdio.h>
int main()
{
int c[10],i,l1,l2;
int a[]= {1,5,9},b[]={3,7,8};

l1=sizeof(a)/(int);

l2=sizeof(b)/(int);

for(i=0,i<l1;i++)
{
c[i]=a[i];
}

for(i=0,i<l2;i++)
{
c[i+l1]=b[i];
}

for(i=0,i<(l1+l2);i++)
{
printf("%d",c[i]);
}

}
整形数组大小:sizeof(数组名)/sizeof(数组类型)。
追问
l1=sizeof(a)/(int);     l2=sizeof(b)/(int);这两句VC++6.0报错,怎么改?
追答
改成4吧,int型占4个字节
本回答被提问者和网友采纳
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
百度网友b30acd1
2019-11-28
知道答主
回答量:4
采纳率:0%
帮助的人:2871
展开全部
、。。。。。。。。
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
夜礼服假面MP
推荐于2018-08-10 · TA获得超过3437个赞
知道大有可为答主
回答量:1034
采纳率:77%
帮助的人:356万
展开全部
基本思想:
1)先在A、B数组中各取第一个元素进行比较,将小的元素放入C数组;
2)取小的元素所在数组的下一个元素与另一数组中上次比较后较大的元素比较,重复上述比较过程,直到某个数组被先排完;
3)将另一个数组剩余元素抄入C数组,合并排序完成。

#include <stdio.h>
void main()
{

int
a[10],b[10],c[20],i,ia,ib,ic;

printf("please input the first array\n");

for(i=0;i<10;i++)

scanf("%d",&a[i]);

for(i=0;i<10;i++)

scanf("%d",&b[i]);

printf("\n");

ia=0;ib=0;ic=0;

while(ia<10&&ib<10)
{

if(a[ia]<b[ib])

{

c[ic]=a[ia];

ia++;

}

else{

c[ic]=b[ib];

ib++;

}

ic++;
}

while(ia<10)
{

c[ic]=a[ia];

ia++;

ic++;
}

while(ib<10)
{

c[ic]=b[ib];

ib++;

ic++;
}

for(i=0;i<20;i++)
{

printf("%5d",c[i]);}
}
本回答被网友采纳
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 2条折叠回答
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式