개발자가 되

프로그래머스 Lv.0

Lv.0 부분 문자열 이어 붙여 문자열 만들기

dltjdud 2025. 2. 5. 23:30

문제설명

길이가 같은 문자열 배열 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

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

 

입출력 예 설명

입출력 예 #1
예제 1번의 입력을 보기 좋게 표로 나타내면 다음과 같습니다.

imy_strings[i]parts[i]부분 문자열

i my_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 합니다.

 

풀이

 

JAVA

class Solution {
    public String solution(String[] my_strings, int[][] parts) {
        String answer = "";

        for (int i = 0; i < my_strings.length; i++) {
            answer += my_strings[i].substring(parts[i][0],parts[i][1] + 1);
        }
        return answer;
    }
}

 

Python

def solution(my_strings, parts):
    result = ''
    for i in range(len(my_strings)):
        result += my_strings[i][parts[i][0] : parts[i][1] + 1]
    return result

*다른 코드

def solution(my_strings, parts):
    return ''.join([x[y[0]:y[1]+1] for x,y in zip(my_strings, parts)])

 

JS

function solution(my_strings, parts) {
    var answer = '';
    for(let i=0; i < my_strings.length;i++){
        answer += my_strings[i].slice(parts[i][0],parts[i][1]+1)
    }
    return answer;
}

*다른 코드

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

'프로그래머스 Lv.0' 카테고리의 다른 글

Lv.0 접미사 배열  (0) 2025.02.06
Lv.0 문자열의 뒤의 n글자  (0) 2025.02.06
Lv.0 배열 만들기 5  (0) 2025.02.05
Lv.0 문자열 여러 번 뒤집기  (0) 2025.02.04
Lv.0 9로 나눈 나머지  (0) 2025.02.04