본문 바로가기
코딩테스트 연습

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

by 신재은👩🏼‍💻 2024. 4. 11.

문제 설명

길이가 같은 문자열 배열 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]라 할 때, 다음을 만족합니다.

 

입출력 예

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

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

// string은 immutable이다. 그래서 +로 연산하면 객체를 계~속 만들어야 한다.

// string을 이어 붙이는 게 많으면 stringbuilder를 쓰는 게 옳다.

// 이거 쓰면 새 객체를 계속 만들지 않는다.
        StringBuilder strbuilder = new StringBuilder();
        for(int i=0; i<my_strings.length; i++) {
            strbuilder.append(my_strings[i].substring(parts[i][0], parts[i][1]+1));
        }
        answer = strbuilder.toString();
        return answer;
    }
}


왜인지는 모르겠는데

 

import java.util.*;

 

class Solution {

    public String solution(String[] my_strings, int[][] parts) {

        String answer = "";

 

        for(int i = 0; i < parts.length; i ++){

            answer += my_strings[i].substring(parts[i][0], parts[i][1] + 1);

        }

 

        return answer;

    }

}

 

이 코드에 좋아요가 가장 많다.

 

코드에 주석으로 적어 놨지만 stringbuilder 쓰는 게 맞다.

'코딩테스트 연습' 카테고리의 다른 글

간단한 식 계산하기  (0) 2024.04.12
l로 만들기  (0) 2024.04.12
순서 바꾸기  (0) 2024.04.11
5명씩  (0) 2024.04.11
할 일 목록  (0) 2024.04.11