春游c++

题目描述

老师带领同学们春游。已知班上有N位同学,每位同学有从0到N - 1的唯一编号。到了集合时间,老师确认是否所有同学都到达了集合地点,就让同学们报出自己的编号。到达的同学都会报出自己的编号,不会报出别人的编号,但有的同学很顽皮,会多次报出。你能帮老师找出有哪些同学没有到达吗?

输入

输入包含2行。第一行包含两个整数N和M,表示班级有N位同学,同学们共有M次报出编号。约定2 < N, M < 1000。第二行包含M个整数,分别为M次报出的编号。约定所有编号都在合理范围内。

输出

输出一行。如果所有同学都到达,则输出N;否则由小到大输出所有未到达的同学编号,空格分隔。

样例输入

复制代码
3 3
0 2 1

样例输出

复制代码
3

代码如下:

cpp 复制代码
#include<bits/stdc++.h>
using namespace std;
long long n,m,a,sum;
bool x[1000];
int main(){
	cin>>n>>m;
	for(int i=0;i<m;i++){
		cin>>a;
		x[a]=1;//让到的同学编号的bool值变为真,剩余则是没到的
	}
	for(int i=0;i<n;i++){
		if(x[i]==0) sum++;
	}
	if(sum==0) cout<<n;//如果所有同学都到达,则输出n
	else{
		for(int i=0;i<n;i++){
		    if(x[i]==0) cout<<i<<" ";//否则由小到大输出所有未到达的同学编号,空格分隔
	    }
	}
    return 0;
}
相关推荐
挖矿大亨1 小时前
C++中深拷贝与浅拷贝的原理
开发语言·c++·算法
Bruce_kaizy1 小时前
c++图论——生成树之Kruskal&Prim算法
c++·算法·图论
雾岛听蓝2 小时前
C++:模拟实现string类
开发语言·c++
XFF不秃头3 小时前
力扣刷题笔记-合并区间
c++·笔记·算法·leetcode
编程之路,妙趣横生3 小时前
STL(七) unordered_set 与 unordered_map 基本用法 + 模拟实现
c++
寂柒3 小时前
c++--
c++
wregjru3 小时前
【读书笔记】Effective C++ 条款3:尽可能使用const
开发语言·c++
历程里程碑4 小时前
滑动窗口秒解LeetCode字母异位词
java·c语言·开发语言·数据结构·c++·算法·leetcode
Tandy12356_4 小时前
手写TCP/IP协议栈——TCP结构定义与基本接口实现
c语言·网络·c++·网络协议·tcp/ip·计算机网络
Helibo445 小时前
2025年12月gesp3级题解
数据结构·c++·算法