使用c语言使得输入第一行一个正整数t,表示有t组数据,每一组第一行一个正整数n,表示序列的长度(序列长度不超过100),每一组第二行和第三行分别为两个长度相等的序列的元素(序列中每个元素都不超过100),然后输出每一组数据输出两个序列中共同出现的元素(顺序根据数的大小从小到大输出),如果一个共同出现的数都没有,输出0即可。
时间: 2024-02-16 08:00:22 浏览: 76
c语言 输出数组元素
这个问题我已经回答过了,以下是完整的 C 语言代码:
```c
#include <stdio.h>
int main() {
int t, n, i, j, k;
int a[100], b[100];
scanf("%d", &t);
while (t--) {
scanf("%d", &n);
for (i = 0; i < n; i++) {
scanf("%d", &a[i]);
}
for (i = 0; i < n; i++) {
scanf("%d", &b[i]);
}
int c[100], cnt = 0;
for (i = 0; i < n; i++) {
for (j = 0; j < n; j++) {
if (a[i] == b[j]) {
int flag = 0;
for (k = 0; k < cnt; k++) {
if (c[k] == a[i]) {
flag = 1;
break;
}
}
if (!flag) {
c[cnt++] = a[i];
}
}
}
}
if (cnt == 0) {
printf("0\n");
} else {
for (i = 0; i < cnt; i++) {
for (j = i + 1; j < cnt; j++) {
if (c[i] > c[j]) {
int tmp = c[i];
c[i] = c[j];
c[j] = tmp;
}
}
}
printf("%d", c[0]);
for (i = 1; i < cnt; i++) {
printf(" %d", c[i]);
}
printf("\n");
}
}
return 0;
}
```
这段代码与之前的代码类似,但是在找到共同出现的元素之后,用 c 数组存储这些元素,并且对 c 数组进行排序,最后输出。注意需要判断是否存在共同出现的元素,如果没有则输出 0。
阅读全文