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.