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);
}
}
성능
- BufferedReader + StringBuilder
- BufferedReader
- Scanner
'Algorithm > Baekjoon' 카테고리의 다른 글
[백준] 1436번 : 영화감독 숌 - Java (0) | 2022.05.10 |
---|---|
[백준] 25083번 : 새싹 - Java (0) | 2022.05.10 |
[백준] 2231번 : 분해합 - Java (0) | 2022.04.12 |
[백준] 2798번 : 블랙잭 - Java (0) | 2022.04.12 |
[백준] 11729번 : 하노이 탑 이동 순서 - Java (0) | 2022.04.07 |
댓글