每组输入数据分为三行,第一行有两个数字n,m(0<n,m<=10000),分别表示集合A和集合B的元素个数.后两行分别表示集合A和集合B.每个元素为不超出int范围的整数,每个元素之间有一个空格隔开.针对每组数据输出一行数据,表示合并后的集合,要求从小到大输出,每个元素之间有一个空格隔开.c语言代码
时间: 2024-04-09 20:33:45 浏览: 214
以下是一个用 C 语言实现的示例代码,用于合并两个集合并按升序输出:
```c
#include <stdio.h>
#include <stdlib.h>
// 比较函数,用于排序
int compare(const void *a, const void *b) {
return (*(int*)a - *(int*)b);
}
int main() {
int n, m;
scanf("%d %d", &n, &m);
// 分别创建集合 A 和集合 B 的数组
int *setA = (int*)malloc(n * sizeof(int));
int *setB = (int*)malloc(m * sizeof(int));
// 读取集合 A
for (int i = 0; i < n; i++) {
scanf("%d", &setA[i]);
}
// 读取集合 B
for (int i = 0; i < m; i++) {
scanf("%d", &setB[i]);
}
// 创建一个新的数组,用于存放合并后的集合
int *mergedSet = (int*)malloc((n + m) * sizeof(int));
// 将集合 A 的元素复制到 mergedSet
for (int i = 0; i < n; i++) {
mergedSet[i] = setA[i];
}
// 将集合 B 的元素复制到 mergedSet
for (int i = 0; i < m; i++) {
mergedSet[n + i] = setB[i];
}
// 对 mergedSet 进行升序排序
qsort(mergedSet, n + m, sizeof(int), compare);
// 输出合并后的集合
for (int i = 0; i < n + m; i++) {
printf("%d ", mergedSet[i]);
}
printf("\n");
// 释放内存
free(setA);
free(setB);
free(mergedSet);
return 0;
}
```
这段代码首先读取两个整数 n 和 m,分别表示集合 A 和集合 B 的元素个数。然后按照题目要求,依次读取集合 A 和集合 B 的元素。接下来,创建一个新的数组 mergedSet,将集合 A 和集合 B 的元素复制到 mergedSet 中。然后使用快速排序函数 qsort 对 mergedSet 进行升序排序。最后,按照顺序输出 mergedSet 中的元素即可。
阅读全文