C语言设两个集合A、B用顺序表表示,求A-B。 【输入形式】 第一行输入两个整数N、M(大于0小于100),分别表示两个集合的长度; 第二行输入第一个集合的N个元素; 第三行输入第二个集合的M个元素; 【输出形式】 输出第一个集合和第二个集合的差集。(若差集为空集,则输出*)用C语言实现
时间: 2023-05-28 09:05:31 浏览: 73
#include <stdio.h>
int main()
{
int n, m;
int a[100], b[100], c[100];
int i, j, k = 0;
int flag;
// 输入集合A和B的元素个数
scanf("%d%d", &n, &m);
// 输入集合A的元素
for (i = 0; i < n; i++)
{
scanf("%d", &a[i]);
}
// 输入集合B的元素
for (i = 0; i < m; i++)
{
scanf("%d", &b[i]);
}
// 求集合A-B
for (i = 0; i < n; i++)
{
flag = 1;
for (j = 0; j < m; j++)
{
if (a[i] == b[j])
{
flag = 0;
break;
}
}
if (flag)
{
c[k++] = a[i];
}
}
// 输出集合A-B
if (k == 0)
{
printf("*\n");
}
else
{
for (i = 0; i < k; i++)
{
printf("%d ", c[i]);
}
printf("\n");
}
return 0;
}
阅读全文