已知数组a中有m个按照升序排列的元素,数组b中有n个按照降序排列的元素,编写程序将a与b中的所有元素按照降序存入到数组c中。

代码如下:

#include<stdio.h>
int a[50],b[50];
int c[100];
main()
{
	int i,m,n,s=0,t=0,k=0;
	printf("请输入数组a的个数:");
	scanf("%d",&m);
	for(i=m-1;i>=0;i--)
		scanf("%d",&a[i]);
	printf("请输入数组b的个数:");
	scanf("%d",&n);
	for(i=0;i<n;i++)
		scanf("%d",&b[i]);
	
	while(s<m&&t<n)
	{
		if(a[s]>=b[t])
			c[k++]=a[s++];
		else if(b[t]>=a[s])
			c[k++]=b[t++];
	}
	while(s<m)   //如果a数组没有放完全部放到k中,则把a中数全部放入c中
			c[k++]=a[s++];
	while(t<n)  //如果b数组没有放完全部放到k中,则把b中数全部放入c中
			c[k++]=b[t++];
	for(i=0;i<m+n;i++)
			printf("%-3d",c[i]);
	printf("\n");
}

运行结果如下:

请输入数组a的个数:3
7 9 18
请输入数组b的个数:3
19 17 3
19 18 17 9  7  3
请按任意键继续. . .

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值