문제
정수 배열 arr와 2개의 구간이 담긴 배열 intervals가 주어집니다.
intervals는 항상 [[a1, b1], [a2, b2]]의 꼴로 주어지며 각 구간은 닫힌 구간입니다. 닫힌 구간은 양 끝값과 그 사이의 값을 모두 포함하는 구간을 의미합니다.
이때 배열 arr의 첫 번째 구간에 해당하는 배열과 두 번째 구간에 해당하는 배열을 앞뒤로 붙여 새로운 배열을 만들어 return 하는 solution 함수를 완성해 주세요.
제한사항
- 1 ≤ arr 의 길이 ≤ 100,000
- 1 ≤ arr 의 원소 < 100
- 1 ≤ a1 ≤ b1 < arr 의 길이
- 1 ≤ a2 ≤ b2 < arr 의 길이
import java.util.Arrays;
class Solution {
public int[] solution(int[] arr, int[][] intervals) {
int[] section1 = Arrays.copyOfRange(arr, intervals[0][0], intervals[0][1]+1);
int[] section2 = Arrays.copyOfRange(arr, intervals[1][0], intervals[1][1]+1);
int section1Len = section1.length;
int section2Len = section2.length;
int[] answer = new int[section1Len+section2Len];
System.arraycopy(section1, 0, answer, 0, section1Len);
System.arraycopy(section2, 0, answer, section1Len, section2Len);
return answer;
}
}
출처
https://school.programmers.co.kr/learn/courses/30/lessons/181895