CodingTest/Programmers

[프로그래머스 고득점 Kit] 전화번호 목록 - Hash(해시) - Lv2

JONG_UK 2023. 5. 31. 14:58
728x90
반응형

⭐️ 코드 (HashSet 이용)

import java.util.*;
class Solution {
    public boolean solution(String[] phone_book) {
        boolean answer = true;

        HashSet<String> hashSet = new HashSet<>();
        for (int i = 0; i < phone_book.length; i++) {
            hashSet.add(phone_book[i]);
        }
        for (int i = 0; i < phone_book.length; i++) {
            for (int j = 0; j < phone_book[i].length(); j++) {
                if (hashSet.contains(phone_book[i].substring(0, j))) {
                    return false;
                }
            }
        }
        return answer;
    }
}

💊 오답 노트

일단 문제가 해시라서 첫 번째 코드는 아래와 같이 작성해 봤다. 하지만 이렇게 작성하면 해시를 쓰나 마나 똑같기 때문에 시간복잡도와 효율성 부분에서 무조건적으로 오류가 발생했다. 다르게 풀어보자...

import java.util.*;
class Solution {
    public boolean solution(String[] phone_book) {
        boolean answer = true;
        Arrays.sort(phone_book);
        for (int i = 0; i < phone_book.length; i++) {
            int length = phone_book[i].length();
            HashMap<String, String> hashMap = new HashMap<>();
            for (int j = i + 1; j < phone_book.length; j++) {
                String s = phone_book[j].substring(0, length);
                hashMap.put(s, phone_book[j]);
                if (hashMap.containsKey(phone_book[i])) {
                    return false;
                }
            }
        }
        return answer;
    }
}

두 번째 풀이는 그냥 해시를 빼버렸다. 하지만 당연하게도 조건이 100만 개의 원소를 가지는데 이중포문으로 풀면 1조 번의 연산이기 때문에 오류가 발생하는 게 맞다.. 위 코드랑 별반 다를 게 없다. 그래서 일단 이것도 틀렸다.

import java.util.*;
class Solution {
    public boolean solution(String[] phone_book) {
        boolean answer = true;

        Arrays.sort(phone_book);

        for (int i = 0; i < phone_book.length; i++) {
            int length = phone_book[i].length();
            for (int j = i + 1; j < phone_book.length; j++) {
                if (phone_book[j].substring(0, length).equals(phone_book[i])) {
                    return false;
                }
            }
        }
        return answer;
    }
}

HashMap을 이용해서 풀어봤다. 이건 정답이지만 굳이 HashMap을 써야할까? 라는 생각이 들었다. HahsSet만 이용해도 될 것 같아서 아래 하나 더 풀이를 남겨보겠다. 시간과 효율성을 한번 체크해 보도록 하자!

import java.util.*;
class Solution {
    public boolean solution(String[] phone_book) {
        boolean answer = true;

        HashMap<String, Integer> hashMap = new HashMap<>();
        for (int i = 0; i < phone_book.length; i++) {
            hashMap.put(phone_book[i], 0);
        }
        for (int i = 0; i < phone_book.length; i++) {
            for (int j = 0; j < phone_book[i].length(); j++) {
                if (hashMap.containsKey(phone_book[i].substring(0, j))) {
                    return false;
                }
            }
        }
        return answer;
    }
}

아래가 HashSet을 이용해서 풀어본 식이다. HashSet이 조금 더 빠르긴하다.

나중에 ContainsKey와 Contains의 속도 차이를 알아보도록 해보자.

import java.util.*;
class Solution {
    public boolean solution(String[] phone_book) {
        boolean answer = true;

        HashSet<String> hashSet = new HashSet<>();
        for (int i = 0; i < phone_book.length; i++) {
            hashSet.add(phone_book[i]);
        }
        for (int i = 0; i < phone_book.length; i++) {
            for (int j = 0; j < phone_book[i].length(); j++) {
                if (hashSet.contains(phone_book[i].substring(0, j))) {
                    return false;
                }
            }
        }
        return answer;
    }
}


👀 후기

정말 다양하고 많은 코드들이 있는 것 같다. 어떻게 풀어야 할지 살짝 막막하다 ㅎㅎ..

728x90
반응형