본문 바로가기
알고리즘 문제 풀이/완전탐색

2309번 : 일곱난쟁이

by 가나무마 2021. 10. 26.
728x90

본 알고리즘 풀이는 Routine Study에서 진행하고 있습니다.
저를 포함한 구성원이 대부분 초보이므로, 원하시는분은 언제라도 들어오셔도 좋습니다.

문의는 댓글 바람.

문제 출처

 

2309번: 일곱 난쟁이

아홉 개의 줄에 걸쳐 난쟁이들의 키가 주어진다. 주어지는 키는 100을 넘지 않는 자연수이며, 아홉 난쟁이의 키는 모두 다르며, 가능한 정답이 여러 가지인 경우에는 아무거나 출력한다.

www.acmicpc.net

[문제 설명]

kks님 블로그에서 처음 본 완전탐색 문제.

총 인원이 9명밖에 되지 않기 때문에 완전탐색으로도 충분히 풀릴 문제다.

시간복잡도는 9명중에 2명을 택하는 9C2 = 36일듯하다. 

 

[처음 생각한 접근 방법]

완전탐색이므로 무지성 for문 돌렸다.

import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStreamReader;
import java.util.Arrays;

class Main {
    public static void main(String[] args) throws IOException {
        BufferedReader bfr = new BufferedReader(new InputStreamReader(System.in));
        int[] dwarfHeights = new int[9];
        int sumOfHeights = 0;
        for (int i = 0; i < 9; i++) {
            dwarfHeights[i] = Integer.parseInt(bfr.readLine());
            sumOfHeights += dwarfHeights[i];
        }
        
        Arrays.sort(dwarfHeights);
        for (int i = 0; i < dwarfHeights.length-1; i++) {
            for (int j = i+1; j < dwarfHeights.length; j++) {
                if (sumOfHeights - dwarfHeights[i] - dwarfHeights[j] == 100) {
                    for (int k = 0; k < dwarfHeights.length; k++) {
                        if (k == i || k == j) continue;
                        System.out.println(dwarfHeights[k]);
                    }
                    return;
                }
            }
        }

        System.out.println(Arrays.toString(dwarfHeights));
    }
}
728x90
반응형

'알고리즘 문제 풀이 > 완전탐색' 카테고리의 다른 글

백준 - 암호 만들기  (0) 2021.12.12
백준 - 한수  (0) 2021.12.12
프로그래머스 - 소수 만들기  (0) 2021.11.25
프로그래머스 - 모의고사  (0) 2021.11.12
프로그래머스 - 모의고사  (0) 2021.08.24