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

JavaScript에서 원하는 합계가 있는 삼중항

<시간/>

숫자 배열을 첫 번째 인수로, 숫자를 두 번째 인수로 취하는 JavaScript 함수를 작성해야 합니다. 함수는 두 번째 인수에 의해 지정된 수까지 합산되는 모든 세 쌍(연속 또는 비연속)의 배열을 준비하고 반환해야 합니다.

예를 들어 -

입력 배열과 숫자가 -

인 경우
const arr = [4, 2, 0, 1, 2, 6, 8, 3, 2, 5];
const num = 8;

그러면 출력 배열은 -

여야 합니다.
const output = [ [ 2, 2, 4 ], [ 1, 3, 4 ], [ 0, 2, 6 ], [ 1, 2, 5 ] ];

예시

다음은 코드입니다 -

const arr = [4, 2, 0, 1, 2, 6, 8, 3, 2, 5];
const num = 8;
const tripletSum = (arr, num) => {
   if (arr.length === 3) {
      if (arr[0]+arr[1]+arr[2] === 0) {
         return [[arr[0],arr[1],arr[2]]];
      };
   };
   const results = [];
   const hashMap = {};
   for (var i=0; i<arr.length; i++) {
      for (var j=i+1; j<arr.length; j++) {
         for (var k=j+1; k<arr.length; k++) {
            if (arr[i]+arr[j]+arr[k] === num) {
               if (!hashMap[arr[i]*arr[j]*arr[k]]) {
                  results.push([arr[i],arr[j],arr[k]]);
                  results[results.length-1].sort();
                  hashMap[arr[i]*arr[j]*arr[k]] = true;
               }
            }
         }
      }
   }
   return results;
};
console.log(tripletSum(arr, num));

출력

다음은 콘솔 출력입니다 -

[ [ 2, 2, 4 ], [ 1, 3, 4 ], [ 0, 2, 6 ], [ 1, 2, 5 ] ]