Developer. Designer

프로그래머스 기초트레이닝 Day12-4

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;
}