JavaScript 中整数列表中的两个数字的最大乘积


我们需要编写一个 JavaScript 函数,其第一个也是唯一的参数接收一个整数数组。

该函数应查找乘以数组中的任意两个元素可获得的最大乘积。我们的条件是,我们必须在 O(n) 的时间和 O(1) 的空间内完成此操作。

例如 -

如果输入数组为 -

const arr = [3, 9, 2, 1, 0];

则输出应为 -

const output = 27;

因为这是最大的乘积,并且可以通过将 3 和 9 相乘得到。

示例

以下为代码 -

const arr = [3, 9, 2, 1, 0];
const maxPairProduct = (arr = []) => {
   let c = Infinity, d = c;
   let a = -Infinity - 1, b = a;
   for (const n of arr) {
      if(n >= a){
         b = a;
         a = n;
      }else if(n >= b){
         b = n;
      };
      if(n <= d){
         c = d;
         d = n;
      }else if(n <= c){
         c = n;
      };
   };
   return Math.max(a * b, c * d);
};
console.log(maxPairProduct(arr));

输出

以下是控制台输出 -

27

更新时间:2021 年 1 月 23 日

218 次浏览

开启你的事业

完成课程后即可获得认证

开始
广告
© . All rights reserved.