【JavaScript】7-33 有理数加法 (15分)
题目:
本题要求编写程序,计算两个有理数的和。
输入格式:
输入在一行中按照a1/b1 a2/b2
的格式给出两个分数形式的有理数,其中分子和分母全是整形范围内的正整数。
输出格式:
在一行中按照a/b
的格式输出两个有理数的和。注意必须是该有理数的最简分数形式,若分母为1,则只输出分子。
输入样例1:
1/3 1/6 |
输出样例1:
1/2 |
输入样例2:
4/3 2/3 |
输出样例2:
2 |
JavaScript代码:
const { parse } = require('path') var readline = require('readline') const rl = readline.createInterface({ input: process.stdin, output: process.stdout }) rl.on('line', function(line) { var tokens = line.split(' ') var first = tokens[0].split('/') var second = tokens[1].split('/') var a1 = parseInt( first[0] ) var b1 = parseInt( first[1] ) var a2 = parseInt( second[0] ) var b2 = parseInt( second[1] ) var ret = sum(a1, a2, b1, b2) console.log(ret) }) function sum(a1, a2, b1, b2) { var a var b var result if (b1 == b2) { b = b1 a = a1 + a2 } else { b = b1 * b2 / gcd(b1, b2) //最小公倍数=两个数相乘再除以最大公约数 a = a1 * b / b1 + a2 * b / b2 } if (b == 1) { result = a } else { result = reduce(a, b) } return result } //求最大公约数 function gcd(n, m ){ if(m == 0) return n return gcd( m, n % m ) } //化简为最简分式 function reduce(m, n) { var min = m > n ? n : m for(let i = min; i >= 2; i--) { if(m % i == 0 && n % i == 0) { m = m / i n = n / i } } if (n == 1) { return m } else { return m + '/' + n } }