按百分比从数字数组中取出部分 JavaScript
javascriptweb developmentobject oriented programming
我们有一个像这样的数字文字数组 −
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 ]