对有理数数组求和并在 JavaScript 中以最简单的形式返回结果
问题
我们需要编写一个JavaScript函数,该函数接受一个由两个子数组组成的数组,每个子数组有两个数字。
两个子数组都以分数形式表示有理数。我们的函数应该将有理数相加,并返回一个由两个数字组成的新数组,代表相加有理数的最简单形式。
示例
以下是代码-
const arr = [
[1, 2],
[1, 3]
];
const findSum = (arr = []) => {
const hcf = (a, b) => b ? hcf(b, a % b) : a;
if(!arr.length){
return null;
};
const [n, d] = arr.reduce(([a, x], [b, y]) => [a*y + b*x, x*y]);
const g = hcf(n, d);
return g === d ? n / d : [n / g, d / g];
};
console.log(findSum(arr));输出结果以下是控制台输出-
[5, 6]
热门推荐
10 香港老妈结婚祝福语简短
11 毕业立体贺卡祝福语简短
12 简短新年年会祝福语
13 评论小品祝福语大全简短
14 恭喜师兄结婚祝福语简短
15 员工集体辞职祝福语简短
16 高中新生祝福语 简短
17 装修祝福语男生搞笑简短
18 生日开业蛋糕祝福语简短