문제
The recent earthquake in Nlogonia did not affect too much the buildings in the capital, which was at the epicenter of the quake. But the scientists found that it affected the dike wall, which now has a significant structural failure in its underground part that, if not repaired quickly, can cause the collapse of the dike, with the consequent flooding the whole capital.
The repair must be done by divers, at a large depth, under extremely difficult and dangerous conditions. But since the survival of the city is at stake, its residents came out in large numbers to volunteer for this dangerous mission.
As is traditional in dangerous missions, each diver received at the start of his/her mission a small card with an identification number. At the end of their mission, the volunteers returned the nameplate, placing it in a repository.
The dike is safe again, but unfortunately it seems that some volunteers did not return from their missions. You were hired for the grueling task of, given the plates placed in the repository, determine which volunteers lost their lives to save the city
입력
The input is composed of two lines. The first line contains two integers N and R, indicating respectively the number of volunteers that went to the mission and the number of volunteers that returned from the mission. Volunteers are identified by numbers from 1 to N. The second line contains R integers, indicating the volunteers which returned from the mission (at least one volunteer returned).
Restrictions
1 ≤ R ≤ N ≤ 104
출력
Your program must produce a single line containing the identifiers of the volunteers who did not return from their missions, in ascending order of their identifications. Leave a blank space after each identifier (notice that, therefore, there must be a blank space after the last identifier in the line). If every volunteer returned, the line must contain a single character ‘*’ (asterisc).
예제 입력 1 복사
5 3
3 1 5
예제 출력 1 복사
2 4
예제 입력 2 복사
6 6
6 1 3 2 5 4
예제 출력 2 복사
*
- c++ 풀이
#include <bits/stdc++.h>
using namespace std;
int n, r;
int arr[10001];
vector<int> ans;
int main() {
ios_base::sync_with_stdio(0);
cin.tie(0);
cout.tie(0);
cin >> n >> r;
for (int i = 0; i < r; i++) {
int idx;
cin >> idx;
arr[idx] = 1;
}
for (int i = 1; i <= n; i++) {
if (arr[i] == 0) {
ans.push_back(i);
}
}
sort(ans.begin(),ans.end());
if(ans.size()==0){
cout << "*";
}else{
for(auto x : ans){
cout << x << " ";
}
}
}
'Algorythms' 카테고리의 다른 글
백준 19947번 투자의 귀재 배주형 java 풀이 (0) | 2024.01.17 |
---|---|
백준 22233번 가희와 키워드 java 풀이 (0) | 2024.01.16 |
프로그래머스 Level3 정수 삼각형 c++ 풀이 (0) | 2024.01.06 |
프로그래머스 Level3 단속카메라 c++ 풀이 (0) | 2024.01.06 |
백준 19637번 IF문 좀 대신 써줘 c++ 풀이 (1) | 2023.12.31 |