[프로그래머스-기초] 접미사 배열

JE·2023년 12월 23일
0

코테/코플릿

목록 보기
39/57

접미사 배열

문제 설명

어떤 문자열에 대해서 접미사는 특정 인덱스부터 시작하는 문자열을 의미합니다. 예를 들어, "banana"의 모든 접미사는 "banana", "anana", "nana", "ana", "na", "a"입니다.
문자열 my_string이 매개변수로 주어질 때, my_string의 모든 접미사를 사전순으로 정렬한 문자열 배열을 return 하는 solution 함수를 작성해 주세요.

제한사항

my_string은 알파벳 소문자로만 이루어져 있습니다.
1 ≤ my_string의 길이 ≤ 100

입출력 예

my_stringresult
"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) {
    let result = [];
    for(let i = 0; i < my_string.length; i++){
        result.push(my_string.slice(i))
    }
    return result.sort()
}

result라는 빈 배열 값을 할당한 변수를 선언해 준다.

문자열은 유사 배열로 for문으로 순환할 수 있다.
각각의 열을 순환하면서 my_string.slice(i)의 값을 result에 push해준다.

마지막으로 사전 순으로 반환해야하기 때문에 sort() 메소드를 작성해 준다.

sort()는 배열을 정렬해 준다.
좀 더 자세히 공부하려면 해당 게시글이 도움이 되는 것 같다.

sort() - hi.anna님

💻 다른 사람이 작성한 코드

function solution(my_string) {
  return Array.from(my_string)
    .map((_, i) => my_string.substring(i))
    .sort();
}

이분은 substring()을 사용하셨다.
substring()은 문자열을 인덱스 값으로 자를 수 있다.

slice()와 비슷하지만 slice()는 배열인 점이 다를 수 있다.

profile
[프론트 애송이] 작은 깨달음도 기록하기

0개의 댓글