백준 5052 전화번호 목록 (Java,자바)

jonghyukLee·2022년 9월 9일
0

이번에 풀어본 문제는
백준 5052번 전화번호 목록 입니다.

📕 문제 링크

❗️코드

import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStreamReader;
import java.util.Arrays;

public class Main {
    public static void main(String[] args) throws IOException {
        BufferedReader br = new BufferedReader(new InputStreamReader(System.in));
        int t = Integer.parseInt(br.readLine());

        StringBuilder sb = new StringBuilder();
        while(t-- > 0) {
            int n = Integer.parseInt(br.readLine());
            String [] input = new String[n];
            for (int i = 0; i < n; i++) {
                input[i] = br.readLine();
            }

            Arrays.sort(input);
            sb.append(check(input)).append("\n");
        }

        System.out.print(sb);
    }
    static String check(String [] arr){
        int size = arr.length - 1;

        for (int i = 0; i < size; i++) {
            String cur = arr[i];
            if (arr[i + 1].startsWith(cur)) return "NO";
        }

        return "YES";
    }
}

📝 풀이

입력된 각 전화번호가 서로의 접두어가 될 수 있는지 여부를 판단하여 YES OR NO를 출력하는 문제입니다.
입력받은 문자열을 오름차순으로 정렬하게 되면, 자신의 바로 뒤에 오는 문자열과의 비교만으로 문제에서 주어진 조건을 비교해볼 수 있습니다.
비교연산은 String.startsWith() 함수로 간단하게 접두어가 될 수 있는지를 확인할 수 있었습니다.

📜 후기

문자열 문제를 풀어보았습니다!

profile
머무르지 않기!

0개의 댓글