根據百分比從 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 ]
廣告
資料結構
網路
關係資料庫管理系統 (RDBMS)
作業系統
Java
iOS
HTML
CSS
Android
Python
C 程式設計
C++
C#
MongoDB
MySQL
Javascript
PHP