Computer >> 컴퓨터 >  >> 프로그램 작성 >> JavaScript

JavaScript에서 Sherlock 및 Array 문제 해결

<시간/>

Watson은 셜록에게 길이가 N인 배열 A를 제공합니다. 그런 다음 그는 배열에 왼쪽 요소의 합이 오른쪽 요소의 합과 같도록 배열에 요소가 있는지 확인하도록 요청합니다.

우리는 이 함수를 작성해야 하고 Numbers 배열을 가져와야 하고 배열에 그러한 숫자가 있으면 인덱스를 반환해야 하고 그렇지 않으면 -1을 반환해야 합니다. 따라서 이 함수의 코드를 작성해 보겠습니다 -

예시

const arr = [1, 2, 3, 4, 5, 7, 3];
const arr2 = [4, 6, 3, 4, 5, 2, 1];
const isSherlockArray = arr => {
   let sum = arr.reduce((acc, val) => acc+val);
   let leftSum = 0;
   for(let i = 0; i < arr.length; i++){
      sum -= arr[i];
      if(sum === leftSum){
         return i;
      };
      leftSum += arr[i];
   };
   return -1;
};
console.log(isSherlockArray(arr));
console.log(isSherlockArray(arr2));

출력

콘솔의 출력은 다음과 같습니다. -

4
-1