접미사 배열
Programmers 코딩 기초 트레이닝
문제 설명
어떤 문자열에 대해서 접미사는 특정 인덱스부터 시작하는 문자열을 의미합니다. 예를 들어, “banana”의 모든 접미사는 “banana”, “anana”, “nana”, “ana”, “na”, “a”입니다.
문자열 my_string
이 매개변수로 주어질 때, my_string
의 모든 접미사를 사전순으로 정렬한 문자열 배열을 반환하는 solution
함수를 작성해 주세요.
제한사항
my_string
은 알파벳 소문자로만 이루어져 있습니다.- 1 ≤
my_string
의 길이 ≤ 100
입출력 예
my_string | result |
---|---|
“banana” | [“a”, “ana”, “anana”, “banana”, “na”, “nana”] |
“programmers” | [“ammers”, “ers”, “grammers”, “mers”, “mmers”, “ogrammers”, “programmers”, “rammers”, “rogrammers”, “rs”, “s”] |
입출력 예 설명
입출력 예 #1
예제 1번의 my_string
는 “banana”로 모든 접미사는 문제의 설명과 같습니다. 이를 사전순으로 정렬하면 “a”, “ana”, “anana”, “banana”, “na”, “nana”이므로 [“a”, “ana”, “anana”, “banana”, “na”, “nana”]를 반환합니다.
입출력 예 #2
예제 2번의 my_string
는 “programmers”이고 모든 접미사는 “programmers”, “rogrammers”, “ogrammers”, “grammers”, “rammers”, “ammers”, “mmers”, “mers”, “ers”, “rs”, “s”입니다. 이를 사전순으로 정렬한 문자열 배열 [“ammers”, “ers”, “grammers”, “mers”, “mmers”, “ogrammers”, “programmers”, “rammers”, “rogrammers”, “rs”, “s”]를 반환합니다.
import java.util.ArrayList;
import java.util.List;
import java.util.Collections;
class Solution {
public List solution(String my_string) {
// 접미사는 특정 인덱스부터 시작하는 문자열을 의미
// 모든 인덱스에서 시작하는 문자열을 만들어야함
char[] charArr = new char[my_string.length()];
charArr = my_string.toCharArray();
List<String> list = new ArrayList<>();
for(int i = 0; i < my_string.length(); i++) {
StringBuilder stringBuilder = new StringBuilder();
for(int j = i; j < my_string.length(); j++) {
stringBuilder.append(charArr[j]);
}
list.add(stringBuilder.toString());
}
// 사전순으로 정렬, 오름차순 정렬.
Collections.sort(list);
return list;
}
}
출처: 프로그래머스 코딩 테스트 연습, https://school.programmers.co.kr/learn/challenges
Leave a comment