按百分比从数字数组中取出部分 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
]

相关文章