|
发表于 2023-10-15 22:39:51
|
显示全部楼层
下面是补全后的代码,注释中有详细的解释:
- #include <bits/stdc++.h>
- using namespace std;
- int a[3001];
- int b[3001];
- int c[3001];
- int main()
- {
- int n, m, k = 0; // 定义变量k用于记录满足条件的人数
- cin >> n >> m;
- for(int i = 0; i < n; i++)
- {
- cin >> a[ i];
- }
- for(int j = 0; j < m; j++)
- {
- cin >> b[j];
- }
- int res = 0, t = 0;
- for(int i = 0; i < n; i++)
- {
- for(int j = 0; j < m; j++)
- {
- if(a[ i] == b[j])
- {
- c[t] = b[j]; // 将相同的元素存入数组c
- t++;
- res++;
- }
- }
- }
- k = n + m - 2 * res; // 计算满足条件的人数k
- for(int i = 0; i < n; i++)
- {
- if(find(c, c + t, a[ i]) == c + t) // 如果a[ i]不在数组c中,则输出
- {
- cout << a[ i] << " ";
- }
- }
- for(int i = 0; i < m; i++)
- {
- if(find(c, c + t, b[ i]) == c + t) // 如果b[ i]不在数组c中,则输出
- {
- cout << b[ i] << " ";
- }
- }
- return 0;
- }
复制代码
这段代码的作用是,输入两个数组a和b,分别表示第一天和第二天参加比赛的人员名单。程序需要找出两天都参加比赛的人员名单,并计算出第二天满足条件的人数k。最后输出第二天不在数组c中的人员名单。
其中,数组c用于存储第一天和第二天都参加比赛的人员名单,t表示数组c的长度,res表示两天都参加比赛的人员数量。通过遍历数组a和b,将相同的元素存入数组c中,并计算出满足条件的人数k。
最后,通过遍历数组a和b,找出不在数组c中的元素,并输出。 |
|