본문 바로가기
컴퓨터 공학/백준

[백준] JAVA 자바 : 덩치 (7568번)

by kim-dev 2024. 5. 25.
반응형

 


각 사람들의 덩치를 구해서, 순위를 책정하는 문제이다.
여기서 덩치가 더 크다는 뜻은 몸무게가 더 무겁고 키가 더 크다는 것이다 (같은 건 포함되지 않음)

 

그래서 내가 생각한 로직은,
우선 모든 사람의 몸무게와 키를 입력받은 다음
그 배열들을 모두 돌면서 자신보다 덩치가 더 큰 사람들의 수를 구해서(이중 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 + " ");
        }
    }
}