강의

멘토링

커뮤니티

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

황준호님의 프로필 이미지
황준호

작성한 질문수

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

5. K번째 큰 수(영상 후반 TreeSet 추가설명)

정렬 후 더하면 왜 오답이 나오는지 궁금합니다!

작성

·

355

1

안녕하세요, 강의 잘 듣고있습니다.

다름이 아니라 저는 먼저 배열을 정렬 한 다음, 큰수 -> 작은수 순서대로 더하면

합한 값도 큰 순서대로 될것이라 생각하여 다름과 같이 코드를 작성하였습니다.

중복된 sum 값은 코드에서 볼 수 있듯, 이전 sum값과 같으면 제거를 해 주었고요.

아래 제 코드가 어떤 면에서 잘못되었는지 궁금합니다!

감사합니다.

int solution(int n, int k, Integer[] arr) {
        // arr 중에 3장을 뽑아 적힌 수를 합하려고 할때, k번째로 큰수
        Arrays.sort(arr, Comparator.reverseOrder());
        int count = 0;
        int sum = 0;
        for (int i = 0; i < n; i++) {
            for (int j = i + 1; j < n; j++) {
                for (int l = j + 1; l < n; l++) {
                    if (sum == arr[i] + arr[j] + arr[l]) continue;
                    sum = arr[i] + arr[j] + arr[l];
                    count++;
                    System.out.println(count + " : " + (arr[i] + arr[j] + arr[l]));
                    if (count == k) return (arr[i] + arr[j] + arr[l]);
                }
            }
        }
        return -1;
    }

답변 1

1

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

안녕하세요^^

9 8 6 5 1 에서 3번째 큰 수는 (9+8+1) 이 아니라 (9+6+5)입니다.

황준호님의 프로필 이미지
황준호

작성한 질문수

질문하기