알고리즘/C++
[백준] 13414 - 수강신청 by C++
엑츄얼리
2023. 6. 14. 12:07
https://www.acmicpc.net/problem/13414
어려운 문제라기보다는 map을 사용하는데 익숙하지 않다보니, map을 이해하고 적응하는 과정인 것 같다.
알고리즘 방식
map 을 사용하여, key : 학번, value : 누른 순서 로 저장하였다.
위와 같이 저장함으로 써, 중복하여 누를 경우, 누른 순서가 최후의 순서로 갱신된다.
이후, map을 vector로 변환하여, 누른 순서를 기준으로 오름차순으로 정렬 후,
수강 가능 인원 수 만큼 출력
소스코드
#include <iostream>
#include <vector>
#include <unordered_map>
#include <algorithm>
using namespace std;
int K, L;
unordered_map<string, int> mp;
bool cmp(const pair<string, int>& a, const pair<string, int>& b) {
return a.second < b.second;
}
void input() {
cin >> K >> L;
string inp;
for (int i = 1; i <= L; i++) {
cin >> inp;
//mp.insert(make_pair(inp, i));
mp[inp] = i;
}
}
void solution() {
vector<pair<string, int>> v(mp.begin(), mp.end());
sort(v.begin(), v.end(), cmp);
for (int i = 0; i < (K < v.size() ? K : v.size()); i++) {
cout << v[i].first << '\n';
}
}
int main(void) {
ios::sync_with_stdio(false);
cin.tie(NULL);
input();
solution();
}
기억해야할 부분
map -> vector 및 custom sorting;
bool cmp(const pair<string, int> &a, const pair<string, int> &b){
return a.second < b.second;
}
map<string, int> mp;
vector<pair<string, int>> v(mp.begin(), mp.end());
sort(v.begin(), v.end(), cmp);
map에 대한 insert는 해당 key값에 대한 value가 존재할 경우 갱신되지 않는다.
mp.insert(make_pair(inp, i));
mp[inp] = i;
//insert의 경우 key: inp에 대한 value가 존재할 경우 해당 값이 i로 갱신되지 않지만,
//map[inp] = i 와 같은 방식의 경우 key: inp에 대한 value를 i로 갱신한다.