본문 바로가기
Algorithm/Baekjoon

[백준] 7568번 : 덩치 - Java

by unknownomad 2022. 4. 26.

https://www.acmicpc.net/problem/7568

 

7568번: 덩치

우리는 사람의 덩치를 키와 몸무게, 이 두 개의 값으로 표현하여 그 등수를 매겨보려고 한다. 어떤 사람의 몸무게가 x kg이고 키가 y cm라면 이 사람의 덩치는 (x, y)로 표시된다. 두 사람 A 와 B의 덩

www.acmicpc.net



주의점

  • 키와 몸무게 모두 클 때 = 덩치가 크다

알고리즘

  • 브루트포스 방식 활용
  • 키와 몸무게 담는 2차원 배열 생성 후 이중 반복문 통해 각 배열의 인덱스 모두 탐색

풀이

1. Scanner

import java.util.Scanner;
 
public class Main {
    public static void main(String[] args) {
 
        Scanner in = new Scanner(System.in);
        int N = in.nextInt();
        int[][] arr = new int[N][2];

        //입력
        for(int i = 0; i < N; i++) {
            arr[i][0] = in.nextInt(); //[i][0]: 몸무게 
            arr[i][1] = in.nextInt(); //[i][1]: 키 
        }
        
        for(int i = 0; i < N; i++) {
            int rank = 1; //rank는 1부터 시작
			
            for(int j = 0; j < N; j++) {
                if(i == j) { //같은 사람은 비교할 필요 X
                    continue;
                }
                /*
                 * i번째 사람과 j번째 사람 비교
                 * i가 j보다 덩치가 작을 경우 rank값 1 증가시키기
                 */
                if(arr[i][0] < arr[j][0] && arr[i][1] < arr[j][1]) {
                    rank++;
                }
            }
            System.out.print(rank + " ");
        }
    }
}

 

2. BufferedReader

import java.io.BufferedReader;
import java.io.InputStreamReader;
import java.io.IOException;
 
public class Main {
    public static void main(String[] args) throws IOException {
 
        BufferedReader br = new BufferedReader(new InputStreamReader(System.in));
        int N = Integer.parseInt(br.readLine());
        int[][] arr = new int[N][2];
 
        //입력
        String[] sp;
        for(int i = 0; i < N; i++) {
            sp = br.readLine().split(" "); //문자열 분리
            arr[i][0] = Integer.parseInt(sp[0]); //[i][0]: 몸무게 
            arr[i][1] = Integer.parseInt(sp[1]); //[i][1]: 키 
        }
        
        for(int i = 0; i < N; i++) {
            int rank = 1; //rank는 1부터 시작
			
            for(int j = 0; j < N; j++) {
                if(i == j) { //같은 사람은 비교할 필요 X
                    continue;
                }
                /*
                 * i번째 사람과 j번째 사람 비교
                 * i가 j보다 덩치가 작을 경우 rank값 1 증가시키기
                 */
                if(arr[i][0] < arr[j][0] && arr[i][1] < arr[j][1]) {
                    rank++;
                }
            }
            System.out.print(rank + " ");
        }
    }
}

 

3. BufferedReader + StringBuilder (or BufferedWriter)

import java.io.BufferedReader;
import java.io.InputStreamReader;
import java.io.IOException;
 
public class Main {
    public static void main(String[] args) throws IOException {
 
        BufferedReader br = new BufferedReader(new InputStreamReader(System.in));
        int N = Integer.parseInt(br.readLine());
        int[][] arr = new int[N][2];
 
        //입력
        String[] str;
        for(int i = 0; i < N; i++) {
            str = br.readLine().split(" ");
            arr[i][0] = Integer.parseInt(str[0]); //[i][0]: 몸무게 
            arr[i][1] = Integer.parseInt(str[1]); //[i][1]: 키 
        }
        
        StringBuilder sb = new StringBuilder();
        for(int i = 0; i < N; i++) {
            int rank = 1; //rank는 1부터 시작
			
            for(int j = 0; j < N; j++) {
                if(i == j) { //같은 사람은 비교할 필요 X
                    continue;
                }
                /*
                i번째 사람과 j번째 사람 비교
                i가 j보다 덩치가 작을 경우 rank값 1 증가시키기
                */
                if (arr[i][0] < arr[j][0] && arr[i][1] < arr[j][1]) {
                    rank++;
                }
            }
            sb.append(rank).append(' ');
        }
        System.out.println(sb);
    }
}

성능

  1. BufferedReader + StringBuilder
  2. BufferedReader
  3. Scanner

 


출처 : https://st-lab.tistory.com/99

댓글