ปัญหา
เราจำเป็นต้องเขียนฟังก์ชัน JavaScript ที่รับอาร์เรย์ของสอง subarrays ที่แต่ละ subarrays แต่ละตัวมีตัวเลขสองตัว
อาร์เรย์ย่อยทั้งสองแสดงจำนวนตรรกยะในรูปแบบเศษส่วน ฟังก์ชันของเราควรบวกจำนวนตรรกยะและส่งกลับอาร์เรย์ใหม่ของตัวเลขสองตัวที่แสดงรูปแบบที่ง่ายที่สุดของจำนวนตรรกยะที่เพิ่มเข้ามา
ตัวอย่าง
ต่อไปนี้เป็นรหัส -
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]