输入描述:
输入包含三行,
第一行包含两个正整数n, m,用空格分隔。n表示第二行第一个升序序列中数字的个数,m表示第三行第二个升序序列中数字的个数。
第二行包含n个整数,用空格分隔。
第三行包含m个整数,用空格分隔。
输出描述:
输出为一行,输出长度为n+m的升序序列,即长度为n的升序序列和长度为m的升序序列中的元素重新进行升序序列排列合并。
全部代码如下:
int main()
{
int m = 0;
int n = 0;
scanf("%d%d", &m, &n);
printf("%d ", m);
printf("%d\n", n);
int arr1[1000] = { 0 };
int arr2[1000] = { 0 };
//输入数据
for (int i = 0; i < n; i++)
{
scanf("%d", &arr1[i]);
}
for (int i = 0; i < n; i++)
{
scanf("%d", &arr2[i]);
}
//输出数据
int i = 0;
int j = 0;
while (i < m && j < n)
{
if (arr1[i] < arr2[j])
{
printf("%d ", arr1[i]);
i++;
}
else
{
printf("%d ", arr2[j]);
j++;
}
}
while (i < m)
{
printf("%d ", arr1[i]);
i++;
}
while (j < n)
{
printf("%d ", arr2[j]);
j++;
}
return 0;
}