https://programmers.co.kr/learn/courses/30/lessons/42579

 

 

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
#include <string>
 
#include <vector>
 
#include <map>
 
#include <algorithm>
 
using namespace std;
 
typedef pair < stringint > si;
 
map < stringint > hash_map; //장르들의 재생횟수 합을 저장하는 해시맵
map < stringvector < pair < intint >>> ranking; //key: 장르, value: pair<고유번호, 재생횟수> 타입의 벡터
 
bool cmp(const pair < stringint > & a,
  const pair < stringint > & b) {
  return a.second > b.second; //내림차순 정렬
}
 
bool cmp2(const pair < intint > & a,
  const pair < intint > & b) {
  return a.second > b.second; //내림차순 정렬
}
 
vector < int > solution(vector < string > genres, vector < int > plays) {
  vector < int > answer;
 
  //hash_map에는 각 장르별 플레이 수 총 합을 저장하고, ranking에는 각 장르의 <고유번호,플레이 횟수>자료형을 벡터에 추가한다.
  for (int i = 0; i < genres.size(); i++) {
    hash_map[genres[i]] += plays[i];
    ranking[genres[i]].push_back({
      i,
      plays[i]
    });
  }
  vector < pair < stringint >> vec(hash_map.begin(), hash_map.end()); //map의 value를 정렬하기 위해 map을 vector로 복사한다.
  sort(vec.begin(), vec.end(), cmp); //value들을 내림차순 정렬.
 
  for (si sit: vec) { //정렬된 vec를 돌면서 answer에 추가한다.
    string k = sit.first; //장르
    vector < pair < intint >> v = ranking[k]; //해당 장르의 <고유번호, 플레이 횟수>벡터를 복사한다.
    sort(v.begin(), v.end(), cmp2); //해당 벡터를 내림차순 정렬.
    if (v.size() == 1) { //벡터 사이즈가 1이면 하나만 선택
      answer.push_back(v[0].first);
    } else { //아니라면 2개 선택
      answer.push_back(v[0].first);
      answer.push_back(v[1].first);
    }
  }
 
  return answer;
}
cs

해시맵 정렬때문에 애를 먹었는데

무조건 벡터에 복사해서 정렬해야한다는 것을 깊게 깨달았다...ㅎ