본문 바로가기
알고리즘/백준

백준 11656번 - 접미사 배열 (Java 8)

by latissimus 2022. 3. 14.

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

 

11656번: 접미사 배열

첫째 줄에 문자열 S가 주어진다. S는 알파벳 소문자로만 이루어져 있고, 길이는 1,000보다 작거나 같다.

www.acmicpc.net

코드:

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));
        StringBuilder sb = new StringBuilder();

        String input = br.readLine();
        String[] suffixArr = new String[input.length()];

        for(int i=0; i<input.length(); i++){
            suffixArr[i] = input.substring(i,input.length());
        }
        Arrays.sort(suffixArr);
        for (String word : suffixArr) {
            sb.append(word + "\n");
        }
        System.out.println(sb);
    }
}

substring과 for문으로 접미사 배열을 만든 후, sort한다.

댓글