프로그래밍/알고리즘

프로그래머스/해시/완주하지 못한 선수

Doublsb 2021. 8. 1. 17:49

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

 

강의 듣기 전 풀이

- Java로 풀이

- 꼴찌는 완주에서 제외

- 동명이인 존재 가능

- 완주하지 못한 선수의 이름 return

 

1) string, int 해시맵을 작성

2) 완주한 선수 이름이 call될 때마다 해시값에 +1

3) 참가자 선수 이름으로 반복, 해시값에 -1

4) -1을 수행할 때, 해시값이 0보다 크지 않다면 해당 이름 리턴

 

class Solution {
    public String solution(String[] participant, String[] completion) {
        
        String answer = "";
        
        //해시맵 작성
        java.util.HashMap<String, Integer> hash = new java.util.HashMap<String, Integer>();
        
        //완주한 선수 이름이 불릴 때마다 해시값에 +1
        for (String e : completion){
            if(hash.containsKey(e)) hash.put(e, hash.get(e) + 1);
            else hash.put(e, 1);
        }
        
        //참가자 선수 이름으로 반복하여, 해시값에 -1
        for (String e : participant){
            
            //해시값이 0보다 커야 -1을 할 수 있음
            if(hash.containsKey(e) && hash.get(e) > 0){
                hash.put(e, hash.get(e) - 1);
            }
            else {
                answer = e;
                break;
            }
        }

        return answer;
    }
}

 

결과 

정확성 : 50.0 / 효율성 : 50.0 / 통과

 

강의 요약

- 강의는 C++이므로 C++로 진행 (본인 C++ 개초보)

- 해시테이블을 구현할 수 있는 map, unordered_map의 두 가지 STL이 존재

 

- key에 의한 접근 시간 차이

종류 실행시간 라이브러리 내부 구현
map O(logN) (주로) binary search tree
unordered_map O(1) hash table

 

- 배열 이터레이션 auto&

for (auto& e : array) 처럼 두면, 컴파일러가 알아서 추론함. C#의 var와 역할은 동일하다.

 

강의 풀이

#include <string>
#include <vector>
#include <unordered_map>

using namespace std;

string solution(vector<string> participant, vector<string> completion) {

    string answer = "";

    unordered_map<string, int> hash;
    for (auto& i : participant) hash[i]++;
    for (auto& i : completion) hash[i]--;

    for (auto& i : hash) {
        if (i.second > 0) {
            answer = i.first;
            break;
        }
    }

    return answer;  
}

 

피드백

C++에서는 containsKey같은 검사 로직이 필요 없다는 것을 보고 충격먹었다.

없던 키에 접근하면 해시값이 기본값으로 생성된다니. 으음...

반응형