Algorithm/Programmers 입문
[프로그래머스 코딩기초 트레이닝] 부분 문자열 이어 붙여 문자열 만들기(JAVA)
JunFe
2023. 11. 1. 10:05
반응형
문제 설명
길이가 같은 문자열 배열 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_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 합니다.
문제풀이
-> 반복문을 통해서 my_strings의 길이 만큼 반복하여 my_strings를 parts값을 이용해서 substring한 값을 answer값에 붙여준다. 이 때, substring 사용법은 [ 시작 인덱스(포함)와 끝 인덱스(미포함)] 이니 참고하면 된다.
코드
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;
}
}
반응형