2의 영역😀
정수 배열 arr가 주어집니다.
배열 안의 2가 모두 포함된 가장 작은 연속된 부분 배열을 return 하는 solution 함수를 완성해 주세요.
단, arr에 2가 없는 경우 [-1]을 return 합니다.
※ 제한 사항
1 ≤ arr의 길이 ≤ 100,000
1 ≤ arr의 원소 ≤ 10
입출력
arr | result |
---|---|
[1, 2, 1, 4, 5, 2, 9] | [2, 1, 4, 5, 2] |
[1, 2, 1] | [2] |
[1, 1, 1] | [-1] |
[1, 2, 1, 2, 1, 10, 2, 1] | [2, 1, 2, 1, 10, 2] |
function solution(arr) {
var answer = [];
// 배열에서 2가 있는 인덱스 찾기
var index1 = arr.indexOf(2);
var index2 = arr.lastIndexOf(2);
// 2가 없는 경우
if (index1 === -1 || index2 === -1) {
return [-1];
}
// 2가 포함된 부분 배열 추출
answer = arr.slice(index1, index2 + 1);
return answer;
}