C语言给你两个序列,长度相等 请找出两个序列中共同出现的元素 由于有多种输出方式,这里我们要求按照所有共同出现的元素从小到大顺序输出,如果重复多次,也只用输出一次,如果一个共同出现的数都没有,输出0即可。 题目保证序列中的元素一定是正整数 输入 第一行一个正整数t,表示有t组数据 每一组第一行一个正整数n,表示序列的长度,序列长度不超过100 每一组第二行和第三行分别为两个序列的元素,序列中每个元素都不超过100,
时间: 2024-02-15 14:03:52 浏览: 84
输出最长公共子序列 c语言
以下是C语言的代码实现:
```
#include <stdio.h>
#define MAX_N 100
int main() {
int t;
scanf("%d", &t);
while (t--) {
int n;
scanf("%d", &n);
int a[MAX_N], b[MAX_N];
for (int i = 0; i < n; i++) {
scanf("%d", &a[i]);
}
for (int i = 0; i < n; i++) {
scanf("%d", &b[i]);
}
int res[MAX_N], cnt = 0;
for (int i = 1; i <= 100; i++) {
int flag = 0;
for (int j = 0; j < n; j++) {
if (a[j] == i) {
flag = 1;
break;
}
}
if (flag) {
for (int j = 0; j < n; j++) {
if (b[j] == i) {
flag = 2;
break;
}
}
}
if (flag == 2) {
res[cnt++] = i;
}
}
if (cnt == 0) {
printf("0\n");
} else {
for (int i = 0; i < cnt; i++) {
printf("%d ", res[i]);
}
printf("\n");
}
}
return 0;
}
```
解释:
1. 首先,通过 `scanf` 读入测试数据组数 `t`。
2. 对于每组测试数据,先读入序列长度 `n`,然后读入两个序列 `a` 和 `b`。
3. 用 `res` 数组存储共同出现的元素,`cnt` 记录共同出现的元素个数。
4. 遍历所有可能出现的元素,即从 1 到 100,如果这个元素在序列 `a` 中出现过,则检查它是否在序列 `b` 中也出现过,如果是,则将它加入 `res` 数组中。
5. 如果 `cnt` 为 0,则说明没有共同出现的元素,输出 0。
6. 如果 `cnt` 不为 0,则按照从小到大的顺序输出 `res` 数组中的元素。
注意事项:
1. 序列中的元素一定是正整数,因此可以用 0 表示一个元素未出现。
2. 如果一个共同出现的数重复出现多次,只需要输出一次即可。
阅读全文