c语言给你两个序列,长度相等 请找出两个序列中共同出现的元素 由于有多种输出方式,这里我们要求按照所有共同出现的元素从小到大顺序输出,如果重复多次,也只用输出一次,如果一个共同出现的数都没有,输出0即可。 题目保证序列中的元素一定是正整数 输入 第一行一个正整数t,表示有t组数据 每一组第一行一个正整数n,表示序列的长度,序列长度不超过100 每一组第二行和第三行分别为两个序列的元素,序列中每个元素都不超过100, 输出 每一组数据输出两个序列中共同出现的元素
时间: 2024-02-15 20:03:54 浏览: 152
输出最长公共子序列 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], c[MAX_N] = {0};
for (int i = 0; i < n; i++) {
scanf("%d", &a[i]);
}
for (int i = 0; i < n; i++) {
scanf("%d", &b[i]);
}
for (int i = 0; i < n; i++) {
for (int j = 0; j < n; j++) {
if (a[i] == b[j]) {
c[a[i] - 1] = 1;
break;
}
}
}
int flag = 0;
for (int i = 0; i < 100; i++) {
if (c[i]) {
if (flag) {
printf(" ");
}
printf("%d", i + 1);
flag = 1;
}
}
if (!flag) {
printf("0");
}
printf("\n");
}
return 0;
}
```
解释:
1. 首先,通过 `scanf` 读入测试数据组数 `t`。
2. 对于每组测试数据,先读入序列长度 `n`,然后读入两个序列 `a` 和 `b`。
3. 用 `c` 数组记录两个序列中共同出现的元素,即如果一个元素在序列 `a` 和 `b` 中都出现过,则将 `c` 数组对应位置设为 1。
4. 遍历 `c` 数组,输出所有值为 1 的下标加 1,即共同出现的元素从小到大顺序输出。
5. 如果没有共同出现的元素,则输出 0。
注意事项:
1. 序列中的元素一定是正整数,因此可以用 0 表示一个元素未出现。
2. 输出时要注意格式,每个数之间用空格隔开,最后要换行。
阅读全文