根據百分比從 JavaScript 數字陣列中取值


我們有一個這樣的數字字面量陣列:

const numbers = [10,6200,20,20,350,900,26,78,888,10000,78,15000,200,1280,2000,450];

我們應該編寫一個函式,它接受一個數字陣列和一個 [0, 100] 之間的數字作為引數,這個數字表示一定的百分比。我們現在將其表示為 x。

現在,我們必須返回原始陣列的前 n 個元素的子陣列,這些元素的總和等於或小於所有陣列元素總和的 x%。

舉個簡單的例子:

const numbers = [12, 10, 6, 8, 4, 2, 8];

對於這個陣列,總和是 50,如果我們提供 25 作為第二個引數(x 的值),那麼我們必須返回前 n 個元素,這些元素的總和等於或小於 50 的 25%,即 12.5。

在這種情況下,應該只返回包含第一個元素的陣列,因為將第二個元素 (10) 加到 12 會超過我們的閾值 (12.5)。

讓我們編寫此程式碼。首先,我們簡單地將陣列簡化為其總和,然後在 for 迴圈中,我們構造一個匹配上述條件的陣列:

示例

const numbers =
[10,6200,20,20,350,900,26,78,888,10000,78,15000,200,1280,2000,450];
const findPercent = (arr, percent) => {
   const sum = arr.reduce((acc, val) => acc+val);
   const part = [];
   let curr = 0;
   for(let i = 0; i < arr.length; i++){
      curr += arr[i];
      if(curr <= (sum*percent)/100){
         part.push(arr[i]);
      } else {
         break;
      };
   };
   return part;
};
console.log(findPercent(numbers, 35));
console.log(findPercent(numbers, 5));
console.log(findPercent(numbers, 65));
console.log(findPercent(numbers, 95));

輸出

控制檯中的輸出將是:

[
   10, 6200, 20, 20,
   350, 900, 26, 78,
   888
]
[ 10 ]
[
   10, 6200, 20,
   20, 350, 900,
   26, 78, 888,
   10000, 78
]
[
   10, 6200, 20, 20,
   350, 900, 26, 78,
   888, 10000, 78, 15000,
   200, 1280
]

更新於:2020年8月24日

瀏覽量 1K+

啟動你的 職業生涯

完成課程獲得認證

開始
廣告
© . All rights reserved.