문제 링크
https://www.acmicpc.net/problem/13414
문제
국민대학교에서는 매 학기 시작 전 종합정보시스템에서 수강신청을 한다. 매 수강신청마다 아주 많은 학생들이 몰려 서버에 많은 부하가 가기 때문에, 국민대학교에서는 수강신청 부하 관리 시스템을 도입하기로 결정하였다. 새로운 관리 시스템은 다음과 같은 방식으로 동작한다.
- 수강신청 버튼이 활성화 된 후, 수강신청 버튼을 조금이라도 빨리 누른 학생이 대기목록에 먼저 들어간다.
- 이미 대기열에 들어가 있는 상태에서 다시 수강신청 버튼을 누를 경우 대기목록의 맨 뒤로 밀려난다.
- 잠시 후 수강신청 버튼이 비활성화 되면, 대기목록에서 가장 앞에 있는 학생부터 자동으로 수강신청이 완료되며, 수강 가능 인원이 꽉 찰 경우 나머지 대기목록은 무시하고 수강신청을 종료한다.
위의 표는 최대 수강 가능 인원이 3명인 알고리즘 수업에 대해 6명의 학생이 수강신청을 진행한 모습이다. 버튼이 비활성화 된 후, 먼저 규칙 1을 적용하여 클릭을 2번 이상 한 학생의 중복된 대기목록을 삭제한다. 중복된 목록을 제거한 후, 맨 앞에서부터 최대 수강 가능 인원인 3명을 선정한다. 표의 맨 오른쪽에는 그 최종결과를 나타낸 모습이다. 이와 같은 방법을 이용하여 최종적으로 수강신청에 성공한 인원을 출력하는 프로그램을 작성하시오.
입력
입력 데이터는 표준 입력을 사용한다. 입력은 1개의 테스트 데이터로 구성된다. 입력의 첫 번째 줄에는 과목의 수강 가능 인원 K(1 ≤ K ≤ 100,000)와 학생들이 버튼을 클릭한 순서를 기록한 대기목록의 길이 L(1 ≤ L ≤ 500,000)이 주어진다. 두 번째 줄부터 L개의 줄에는 수강신청을 버튼을 클릭한 학생의 학번이 클릭 순서대로 주어진다. 학번은 8자리의 숫자로 이루어져 있다.
출력
출력은 표준 출력을 사용한다. 입력받은 데이터에 대해, 수강신청 관리 시스템의 규칙을 적용한 후 수강신청에 성공한 인원의 학번을 한 줄에 1개씩 출력한다.
예제 입력 1
3 8
20103324
20133221
20133221
20093778
20140101
01234567
20093778
20103325
예제 출력 1
20103324
20133221
20140101
알고리즘 분류
- 자료 구조
풀이
map 자료구조를 활용하여, 학번이 출현한 순서를 기록해 두는데, 여기서 이미 출현한 학번이면 출현한 순서를 변경한다.
모든 입력을 받았다면 vector로 옮기고 출현한 순서대로 오름차순한다.
마지막으로 min(K, vector의 size)개만큼 vector의 원소를 0번째부터 출력해준다.
코드
#include <iostream>
#include <string>
#include <cmath>
#include <unordered_set>
#include <unordered_map>
#include <bitset>
#include <ctime>
#include <stack>
#include <queue>
#include <vector>
#include <algorithm>
#include <climits>
#define FASTIO cin.tie(NULL); cout.tie(NULL); ios::sync_with_stdio(false);
#define MAX 500001
#define LL long long
#define INF 1e9
using namespace std;
int K, L;
unordered_map<string, int> MAP;
unordered_map<string, int>::iterator IT;
vector<pair<string, int> > Vec;
void Input() {
cin >> K >> L;
for (int i = 0; i < L; i++) {
string S;
cin >> S;
if (MAP.find(S) == MAP.end()) {
MAP.insert(make_pair(S, i));
}
else {
MAP[S] = i;
}
}
}
bool Comp(pair<string, int> A, pair<string, int> B) {
return (A.second < B.second);
}
void Settings() {
for (auto IT = MAP.begin(); IT != MAP.end(); IT++) {
Vec.push_back(make_pair(IT->first, IT->second));
}
sort(Vec.begin(), Vec.end(), Comp);
}
void Find_Answer() {
for (int i = 0; i < min(K, (int)Vec.size()); i++) {
cout << Vec[i].first << "\n";
}
}
int main() {
FASTIO
Input();
Settings();
Find_Answer();
return 0;
}
'BOJ > Silver' 카테고리의 다른 글
[BOJ/Silver 1] 백준 2002 추월(C++) (0) | 2022.05.06 |
---|---|
[BOJ/Silver 3] 백준 16165 걸그룹 마스터 준석이(C++) (0) | 2022.05.06 |
[BOJ/Silver 3] 백준 2910 빈도 정렬(C++) (0) | 2022.05.06 |
[BOJ/Silver 3] 백준 1269 대칭 차집합(C++) (0) | 2022.05.05 |
[BOJ/Silver 4] 백준 11652 카드(C++) (0) | 2022.05.05 |