在 JavaScript 中将数字拆分为 n 个彼此靠近的部分

问题

我们需要编写一个 JavaScript 函数,它接受一个数字 num 作为第一个参数,另一个数字部分作为第二个参数。

我们的函数应该将数字 num 精确地分成(部分)数字,我们应该记住这两个条件 -

  • 数字应尽可能接近

  • 数字应该是偶数(如果可能的话)。

并且数字的顺序并不重要。

例如,如果函数的输入是 -

输入

const num = 20;
const parts = 6;

输出

const output = [3, 3, 3, 3, 4, 4];

示例

以下是代码 -

const num = 20;
const parts = 6;
const splitNumber = (num = 1, parts = 1) => {
   let n = Math.floor(num / parts);
   const arr = [];
   for (let i = 0; i < parts; i++){
      arr.push(n)
   };
   if(arr.reduce((a, b)=> a + b,0) === num){
      return arr;
   };
   for(let i = 0; i < parts; i++){
      arr[i]++;
      if(arr.reduce((a, b) => a + b, 0) === num){
         return arr;
      };
   };
};
console.log(splitNumber(num, parts));
输出结果
[ 4, 4, 3, 3, 3, 3 ]