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

JavaScript의 선형 시간에서 두 정수의 최대 곱


양수와 음수를 모두 포함하는 숫자 배열을 가져와 한 번의 순회에서 두 숫자의 최대 곱을 반환하는 JavaScript 함수를 작성해야 합니다.

이 함수의 코드를 작성해 봅시다 -

예시

const arr = [-1, -3, -4, 2, 0, -5];
const arr2 = [2, 3, 5, 7, -7, 5, 8, -5];
const produce = arr => arr.reduce((acc, val) => acc*val);
const maximumProduct = (arr = []) => {
   const [first] = arr;
   if(!first){
      return 0;
   };
   const creds = arr.reduce((acc, val) => {
      const { min, max } = acc;
      if(val > max[0]){
         max[1] = max[0];
         max[0] = val;
         return acc;
      };
      if(val < min[0]){
         min[1] = min[0];
         min[0] = val;
         return acc;
      };
      if(val > max[1]){
         max[1] = val;
         return acc;
      };
      if(val < min[1]){
         min[1] = val;
         return acc;
      };
      return acc;
   }, {
      min: [first, first],
      max: [first, first]
   });
   const { max, min } = creds;
   return produce(max) > produce(min) ? produce(max) : produce(min);
};
console.log(maximumProduct(arr));
console.log(maximumProduct(arr2));

출력

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

20
56