[코딩테스트] JavaScript/[코테] 프로그래머스

[프로그래머스 / JS ] Lv.0 / 181909 : 접미사 배열

jini-dev 2025. 1. 7. 20:53
SMALL

접미사 배열(링크)

문제 설명
어떤 문자열에 대해서 접미사는 특정 인덱스부터 시작하는 문자열을 의미합니다. 예를 들어, "banana"의 모든 접미사는 "banana", "anana", "nana", "ana", "na", "a"입니다.
문자열 my_string이 매개변수로 주어질 때, my_string의 모든 접미사를 사전순으로 정렬한 문자열 배열을 return 하는 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"]를 return 합니다.

입출력 예 #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"]를 return 합니다

 

문제 풀이

function solution(my_string) {
    const answer = []
    for(let i = 1; i<=my_string.length;i++){
        answer.push(my_string.slice(-i));
    }
    return answer.sort();
}

 

answer 배열을 선언한다.

for 반복문을 사용하여 i가 1 부터 my_string 의 length(길이) 까지 증가하도록 적용하고,

answer 배열에 my_string 문자열의 slice 메소드를 사용한 값을 push 하도록 한다.

 

i가 1일때 my_string.slice(-1)의 값은 'a'

i가 2일때 my_string.slice(-2)의 값은 'na' 이다

 

차례대로 answer 배열에 push가 된 값에다 sort 메소드를 사용하여 사전순으로 정렬한 문자열 배열을 반환한다.

LIST