[백준]10814번: 나이순 정렬

이진솔·2024년 5월 1일
0
post-thumbnail

# 문제

온라인 저지에 가입한 사람들의 나이와 이름이 가입한 순서대로 주어진다. 이때, 회원들은 나이가 증가하는 순으로, 나이가 같으면 먼저 가입한 사람이 앞에 오는 순서로 정렬하는 프로그램을 작성하시오.

[입력]
첫째 줄에 온라인 저지 회원의 수 N이 주어진다. (1 <= N <= 100,000)
둘째 줄부터 N개의 줄에는 각 회원의 나이와 이름이 공백으로 구분되어 주어진다.
나이ㅏ는 1보다 크거나 같으며, 200보다 작거나 같은 정수이고, 이름은 알파벳 대소문자로 이루어져 있고, 길이가 100보다 작거나 같은 문자열이다. 입력은 가입한 순서로 주어진다.

[출력]
첫째 줄부터 총 N개의 줄에 걸쳐 온라인 저지 회원을 나이 순, 나이가 같으면 가입한 순으로 한 줄에 한 명씩 나이와 이름을 공백으로 구분해 출력한다.

# 정답

import java.util.Arrays;
import java.util.Comparator;
import java.util.Scanner;
import java.util.StringTokenizer;

public class Main {
    public static void main(String[] args) {
        Scanner sc = new Scanner(System.in);
        int N = Integer.parseInt(sc.nextLine());
        String[][] str = new String[N][2]; // 이차형 배열 생성
        StringBuilder sb = new StringBuilder();

        for (int i = 0; i < N; i++) {
            StringTokenizer st = new StringTokenizer(sc.nextLine());
            str[i][0] = st.nextToken();
            str[i][1] = st.nextToken();
        }

        Arrays.sort(str, new Comparator<String[]>() { // Comparator 인터페이스 구현
            @Override
            public int compare(String[] s1, String[] s2) {
                return Integer.parseInt(s1[0]) - Integer.parseInt(s2[0]);
            }
        });

        for (int i = 0; i < N; i++) {
            sb.append(str[i][0]).append(" ").append(str[i][1]).append("\n");
        }

        System.out.println(sb);
    }

}

# 알아가야 할 것

  1. Comparator 사용 조건: Array, ListCollectons 일 때 사용 가능
    => Arrays.sort() // Collections.sort()
  2. return Integer.parseInt(s1[0]) - Integer.parseInt(s2[0]);에서 반환 값
  • 음수: 첫 번째 배열의 첫 번째 요소 < 두 번째 배열의 첫 번째 요소
    => 첫 번째 배열이 두번째 배열 앞에 위치
  • 양수: 첫 번째 배열의 첫 번째 요소 > 두 번째 배열의 첫 번쨰 요소
    => 두 번째 배열 뒤 첫 번째 배열
  • 0: 두 요소가 같은 값
profile
성장하기

0개의 댓글