Notice
Recent Posts
Recent Comments
Link
일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
1 | 2 | |||||
3 | 4 | 5 | 6 | 7 | 8 | 9 |
10 | 11 | 12 | 13 | 14 | 15 | 16 |
17 | 18 | 19 | 20 | 21 | 22 | 23 |
24 | 25 | 26 | 27 | 28 | 29 | 30 |
31 |
Tags
- IaC
- rds
- SageMaker
- fcm
- 병목
- lambda
- CHECK
- Validation
- Lamda
- serverless
- amazonqcli
- terraform
- aws
- kubernetes
- sns
- cloudwatch
Archives
- Today
- Total
잡다한 IT 지식
2309번 : 일곱난쟁이 본문
본 알고리즘 풀이는 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));
}
}
'알고리즘 문제 풀이 > 완전탐색' 카테고리의 다른 글
백준 - 암호 만들기 (0) | 2021.12.12 |
---|---|
백준 - 한수 (0) | 2021.12.12 |
프로그래머스 - 소수 만들기 (0) | 2021.11.25 |
프로그래머스 - 모의고사 (0) | 2021.11.12 |
프로그래머스 - 모의고사 (0) | 2021.08.24 |