강의

멘토링

커뮤니티

인프런 커뮤니티 질문&답변

임채원님의 프로필 이미지
임채원

작성한 질문수

자바(Java) 알고리즘 문제풀이 입문: 코딩테스트 대비

5. 중복확인

HashMap을 사용한 방법 맞는지 질문드립니다.

작성

·

318

0

안녕하세요.

강의 중 HashMap을 사용하면 O(n)으로 풀이 할 수 있다고 하셔서 풀어보았습니다. 이 방법이 O(n) 맞나요?

    private static char solution(int n, int[] nArr) {
        HashMap<Integer, Integer> map = new HashMap<>();
        for (int x : nArr) {
            map.put(x, map.getOrDefault(x, 0) + 1);
            if (map.get(x) >= 2) {
                return 'D';
            }
        }

        return 'U';
    }

위 방법이 O(n)이 맞다면, test결과 속도가 아래와 같이 이중 for문으로 풀이한 것이 속도가 더 빠른데, 그래도 코딩테스트 풀이할때는 O(n) 방법으로 풀이하는 것이 올바른거겠죠??

아니면 혹시 HashMap의 getOrDefault 내부에서 for문이 돌아가서 O(n)이 아닌건지.. 궁금합니다!

    private static char solution(int n, int[] nArr) {
        for (int i = 0; i < n; i++) {
            for (int j = i + 1; j < n; j++) {
                if (nArr[i] == nArr[j]) {
                    return 'D';
                }
            }
        }

        return 'U';
    }

답변 1

0

김태원님의 프로필 이미지
김태원
지식공유자

안녕하세요^^

해쉬로 푸는게 좋습니다.

임채원님의 프로필 이미지
임채원

작성한 질문수

질문하기