문제 설명
길이가 같은 문자열 배열 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번의 입력을 보기 좋게 표로 나타내면 다음과 같습니다.
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 합니다.
코드 및 설명
public String solution(String[] my_strings, int[][] parts) {
parts가 2차원 정수이기때문에 for문 안에서 answer 값을 더해주어야한다.
str.substring(시작,끝) 을 설정해주어
str[i] 안에서 [0,4] , [1,2], [3,5], [7,7] 을 for문 안에서 지정해주면된다.
즉 str[i][시작,끝] 이라고 보면 된다.
for (int i = 0; i < my_strings.length; i++) {
String str = my_strings[i];
answer += my_strings[i].substring(parts[i][0], parts[i][1]+1);
}
for문으로 i번째의 my_strings를 지정해주고 이 값을 str에 저장해준다.
여기서 parts는 my_strings에 해당하는 번째의 배열을 가져와야하기 때문에
i로 고정해주고, parts에서 시작인 1번째를 가져와야하므로 0으로 고정시켜주면된다.
parts에서 끝인 2번째를 가져와야하므로 1로 해주는데, 여기서 문제에서처럼
하나의 문자를 더 가져와야하기때문에 +1을 해주면된다.
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;
}
}