[프로그래머스] 부분 문자열 이어 붙여 문자열 만들기

백승연·2024년 1월 9일
0

프로그래머스 - Lv. 0

목록 보기
57/60
post-thumbnail

🗒️ 문제

길이가 같은 문자열 배열 my_strings와 이차원 정수 배열 parts가 매개변수로 주어집니다. parts[i]는 [s, e] 형태로, my_string[i]의 인덱스 s부터 인덱스 e까지의 부분 문자열을 의미합니다. 각 my_strings의 원소의 parts에 해당하는 부분 문자열을 순서대로 이어 붙인 문자열을 return 하는 solution 함수를 작성해 주세요.


제한 사항

  • 1 ≤ my_strings의 길이 = parts의 길이 ≤ 100
  • 1 ≤ my_strings의 원소의 길이 ≤ 100
  • parts[i]를 [s, e]라 할 때, 다음을 만족합니다.
    • 0 ≤ s ≤ e < my_strings[i]의 길이

입출력 예

my_stringspartsresult
["progressive", "hamburger", "hammer", "ahocorasick"][[0, 4], [1, 2], [3, 5], [7, 7]]"programmers"

입출력 예 설명

입출력 예 #1

  • 예제 1번의 입력을 보기 좋게 표로 나타내면 다음과 같습니다.
imy_strings[i]parts[i]부분 문자열
0"progressive"[0, 4]"progr"
1"hamburger"[1, 2]"am"
2"hammer"[3, 5]"mer"
3"ahocorasick"[7, 7]"s"

각 부분 문자열을 순서대로 이어 붙인 문자열은 "programmers"입니다. 따라서 "programmers"를 return 합니다.


🖋️ 나의 풀이

function solution(my_strings, parts) {
   let result = [];
    for (let i = 0; i < my_strings.length; i++) {
        result.push(my_strings[i].slice(parts[i][0], parts[i][1] + 1));
    }
    return result.join("");
}

💡 다른 사람들의 풀이

# 1

function solution(my_strings, parts) {
    return parts.map(([s, e], i) => {
        return my_strings[i].slice(s, e + 1)
    }).join('')
}

# 2

const solution=(s,p)=>s.map((v,i)=>v.slice(p[i][0],p[i][1]+1)).join('');



📝 모르는 내용 찾아보기

profile
공부하는 벨로그

0개의 댓글