이번에 풀어본 문제는
백준 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() 함수로 간단하게 접두어가 될 수 있는지를 확인할 수 있었습니다.
문자열 문제를 풀어보았습니다!