上海大学1998数据结构考研试题

luoyeyiliunian 2016-04-15 10:53:40
已知两个定长数组,它们分别存放两个非降序有序序列,请编写程序把第二个数组序列中的数逐个插入到前一个数组序列中,完成后两个数组中的数分别有序(非降序)并且第一数组中所有的数都不大于第二个数组中的任意一个数。注意,不能另开辟数组,也不能对任意一个数组进行排序操作。例如,

第一个数组为:4,12,28

第二个数组为:1,7,9,29,45

输出结果为:1,4,7--------------第一个数组

9,12,28,29,45---------第二个数组
还望大神指教!
...全文
525 1 打赏 收藏 转发到动态 举报
写回复
用AI写文章
1 条回复
切换为时间正序
请发表友善的回复…
发表回复
cocoabird 2016-04-15
  • 打赏
  • 举报
回复
int a[3]={2,12,28};
	int b[5]={1,7,9,29,45};
	for (int i=0;i<3;i++)
	{
		for (int j=0;j<5;j++)
		{
			if (a[i]>b[j])
			{
				a[i]=a[i]^b[j];
				b[j]=a[i]^b[j];
				a[i]=a[i]^b[j];
				for (int k=j+1;k<4;k++)
				{
					if (b[j]>b[k])
					{
						b[j]=b[j]^b[k];
						b[k]=b[k]^b[j];
						b[j]=b[k]^b[j];
					}
				}
			}
		}
	}
	
	printf("%d %d %d\n",a[0],a[1],a[2]);
	printf("%d %d %d %d %d\n",b[0],b[1],b[2],b[3],b[4]);

   return 0;

}

64,649

社区成员

发帖
与我相关
我的任务
社区描述
C++ 语言相关问题讨论,技术干货分享,前沿动态等
c++ 技术论坛(原bbs)
社区管理员
  • C++ 语言社区
  • encoderlee
  • paschen
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
  1. 请不要发布与C++技术无关的贴子
  2. 请不要发布与技术无关的招聘、广告的帖子
  3. 请尽可能的描述清楚你的问题,如果涉及到代码请尽可能的格式化一下

试试用AI创作助手写篇文章吧