[백준 2866] 문자열 잘라내기 (JAVA)

solser12·2021년 9월 1일
0

Algorithm

목록 보기
12/56

문제


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

풀이


이분탐색을 이용해 해결할 수 있습니다. 행과 열을 바꿔서 이용하면 더 편하게 구현할 수 있습니다.

코드


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

public class Main {

    static int R, C;
    static char[][] table;

    public static void main(String[] args) throws IOException {

        BufferedReader br = new BufferedReader(new InputStreamReader(System.in));

        StringTokenizer st = new StringTokenizer(br.readLine());
        C = Integer.parseInt(st.nextToken());
        R = Integer.parseInt(st.nextToken());
        table = new char[R][C];

        for (int i = 0; i < C; i++) {
            String input = br.readLine();
            for (int j = 0; j < R; j++) {
                table[j][i] = input.charAt(j);
            }
        }

        System.out.println(binarySearch());
        br.close();
    }

    public static int binarySearch() {
        int ans = 0, left = 1, right = C - 1;
        while (left <= right) {
            int mid = (left + right) >> 1;
            if (check(mid)) {
                ans = mid;
                left = mid + 1;
            } else {
                right = mid - 1;
            }
        }

        return ans;
    }

    public static boolean check(int start) {
        String[] arr = new String[R];
        for (int i = 0; i < R; i++) {
            arr[i] = String.valueOf(Arrays.copyOfRange(table[i], start, C));
        }
        Arrays.sort(arr);

        for (int i = 0; i < R - 1; i++) {
            if (arr[i].equals(arr[i+1])) return false;

        }

        return true;
    }
}
profile
더 나은 방법을 생각하고 고민합니다.

0개의 댓글