题解 | #整型数组合并#
整型数组合并
http://www.nowcoder.com/practice/c4f11ea2c886429faf91decfaf6a310b
#include <stdio.h>
int cmp (int *a, int *b)
{
return (*a - *b);
}
int main()
{
int n1 = 0, n2 = 0, n3 = 0, n4 = 0;
int a1[1024] = {0};
int a2[1024] = {0};
scanf("%d", &n1);
for (int i = 0; i < n1; i++) {
scanf("%d", &a1[i]);
}
scanf("%d", &n2);
for (int i = n1; i < n1 + n2; i++) {
scanf("%d", &a1[i]);
}
scanf("%d", &n3);
for (int i = 0; i < n3; i++) {
scanf("%d", &a2[i]);
}
scanf("%d", &n4);
for (int i = n3; i < n3 + n4; i++) {
scanf("%d", &a2[i]);
}
qsort(a1, n1+n2, sizeof(int), cmp);
qsort(a2, n3+n4, sizeof(int), cmp);
for(int i = 0; i < n1+n2; i++) {
if (a1[i] != a1[i-1]) {
printf("%d", a1[i]);
}
}
printf("\n");
for(int i = 0; i < n3+n4; i++) {
if (a2[i] != a2[i-1]) {
printf("%d", a2[i]);
}
}
return 0;
} 描述
将两个整型数组按照升序合并,并且过滤掉重复数组元素。
输出时相邻两数之间没有空格。
请注意本题有多组样例。输入描述:
输入说明,按下列顺序输入:
1 输入第一个数组的个数
2 输入第一个数组的数值
3 输入第二个数组的个数
4 输入第二个数组的数值输出描述:
输出合并之后的数组
比较麻烦的是处理输入,题意并没有给出条件“2 <= 数组数 <=4”以及“数组两两合并”(摊手)。

