반응형
각 사람들의 덩치를 구해서, 순위를 책정하는 문제이다.
여기서 덩치가 더 크다는 뜻은 몸무게가 더 무겁고 키가 더 크다는 것이다 (같은 건 포함되지 않음)
그래서 내가 생각한 로직은,
우선 모든 사람의 몸무게와 키를 입력받은 다음
그 배열들을 모두 돌면서 자신보다 덩치가 더 큰 사람들의 수를 구해서(이중 for문)
자신보다 덩치가 더 큰 사람들의 수 + 1을 순위로 출력하는 것이다.
브루트포스는... 진짜 공부 많이 해야 겠다...
사실 이 문제도 문제를 제대로 이해 못 해서 거의 40분이나 걸려서 풂...ㅋㅋㅋㅋ 진짜 실화야?
실버 단계는 큰 고민 안 하고 풀었었는데... 브루트포스는 실버만 돼도 어렵게 느껴지네....
import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStreamReader;
import java.util.Arrays;
import java.util.Collections;
import java.util.StringTokenizer;
public class Bulk {
public static int stoi(String st) {
return Integer.parseInt(st);
}
public static void main(String[] args) throws IOException {
BufferedReader br = new BufferedReader(new InputStreamReader(System.in));
int N = stoi(br.readLine());
int[][] person = new int[N][2];
for (int i=0; i<N; i++) {
StringTokenizer st = new StringTokenizer(br.readLine());
person[i][0] = stoi(st.nextToken());
person[i][1] = stoi(st.nextToken());
}
// 배열 하나씩 돌면서 자기보다 덩치가 큰 요소가 있는지 확인
for (int i=0; i<N; i++) {
int count = 1;
for (int j=0; j<N; j++) {
if (i == j) continue;
// 덩치가 큰 사람이 있다면
if (person[i][0] < person[j][0] && person[i][1] < person[j][1]) {
count++; // 순위를 1씩 낮춘다
}
}
System.out.print(count + " ");
}
}
}
'컴퓨터 공학 > 백준' 카테고리의 다른 글
[백준] JAVA 자바 : 일곱 난쟁이 (2309번) (0) | 2024.06.21 |
---|---|
[백준] JAVA 자바 : 영화감독 숌 (1436번) (0) | 2024.06.21 |
[백준] JAVA 자바 : 체스판 다시 칠하기 (1018번) (0) | 2024.05.24 |
[백준] JAVA 자바 : 한수 (1065번) (0) | 2024.05.18 |
[백준] JAVA 자바 : 셀프 넘버 (4673번) (0) | 2024.05.17 |