在JavaScript中找到最简单的求和分数形式的函数

我们有一个这样的数组数组-

const arr = [[12, 56], [3, 45], [23, 2], [2, 6], [2, 8]];

请注意,虽然数组可以具有任意数量的元素,但是每个子数组应严格包含两个数字。

每个子数组中的两个数字代表一个分数。像第一个子数组表示的分数是12/56,第二个子数组表示的分数是3/45,依此类推。

我们需要编写一个JavaScript函数,该函数接受一个这样的数组并计算所有子数组表示的分数之和。

我们需要以分数形式计算总和(即,不将其转换为小数)。

并将总和作为表示结果分数的两个元素的数组返回。

因此,让我们为该函数编写代码-

示例

为此的代码将是-

const arr = [[12, 56], [3, 45], [23, 2], [2, 6], [2, 8]];
const gcd = (a, b) => {
   let num = 2, res = 1;
   while(num >= Math.min(a, b)){
      if(a % num === 0 && b % num === 0){
         res = num;
      };
      num++;
   };
   return res;
}
const sumFrac = (a, b) => {
   const aDenom = a[1], aNumer = a[0];
   const bDenom = b[1], bNumer = b[0];
   let resDenom = aDenom * bDenom;
   let resNumer = (aDenom*bNumer) + (bDenom*aNumer);
   const greatestDivisor = gcd(resDenom, resNumer);
   return [resNumer/greatestDivisor, resDenom/greatestDivisor];
};
const sumArrayOfFractions = arr => {
   return arr.reduce((acc, val) => sumFrac(acc, val));
};
console.log(sumArrayOfFractions(arr));

输出结果

控制台中的输出将为-

[ 1731, 140 ]