说我们有2/4分数,它可以减少到1/2。有没有可以减少的javascript函数?
答案 0 :(得分:69)
// Reduce a fraction by finding the Greatest Common Divisor and dividing by it.
function reduce(numerator,denominator){
var gcd = function gcd(a,b){
return b ? gcd(b, a%b) : a;
};
gcd = gcd(numerator,denominator);
return [numerator/gcd, denominator/gcd];
}
reduce(2,4);
// [1,2]
reduce(13427,3413358);
// [463,117702]
答案 1 :(得分:9)
不,但你可以很容易地自己写一个。 基本上你需要将分数的顶部和底部除以它们的“最大公分母”...你可以用欧几里德算法计算出来。
请点击此处了解详情:http://www.jimloy.com/number/euclids.htm
编辑:
代码(因为每个人似乎都在这样做,但这不使用递归)
var FractionReduce = (function(){
//Euclid's Algorithm
var getGCD = function(n, d){
var numerator = (n<d)?n:d;
var denominator = (n<d)?d:n;
var remainder = numerator;
var lastRemainder = numerator;
while (true){
lastRemainder = remainder;
remainder = denominator % numerator;
if (remainder === 0){
break;
}
denominator = numerator;
numerator = remainder;
}
if(lastRemainder){
return lastRemainder;
}
};
var reduce = function(n, d){
var gcd = getGCD(n, d);
return [n/gcd, d/gcd];
};
return {
getGCD:getGCD,
reduce:reduce
};
}());
alert(FractionReduce.reduce(3413358, 13427));
答案 2 :(得分:5)
要减少分数,请将分子和分母除以最大公因数。 Phrogz和David已经提供了源代码..
但是,如果您正在搜索用于处理分数的JavaScript库,那么这里有一些可供选择。
以下是使用Ratio.js的示例。
var a = Ratio(2,4);
a.toString() == "2/4";
a.simplify().toString() == "1/2"; // reduce() returns a clone of the Ratio()
a.toString() == "2/4"; // Ratio functions are non-destructive.
答案 3 :(得分:1)
我知道已经有了答案,但我希望分享一个JS库,当我找到将十进制数转换为分数和减少分数时,我找到了这个库。
图书馆拨打Fraction.js,这对我很有帮助,为我节省了大量时间和工作。 希望它对其他人非常有用!
答案 4 :(得分:1)
我知道这是一篇旧帖子,但我将接受的答案转换为循环解决方案而不是递归函数。这将提高内存效率并且可能更快(不需要内存堆栈操作和执行调用)。
function reduce(numerator, denominator) {
var a = numerator;
var b = denominator;
var c;
while (b) {
c = a % b; a = b; b = c;
}
return [numerator / a, denominator / a];
}
内存占用只有 5 个 Number 结构和一个简单的循环。
答案 5 :(得分:0)
这是一个使用ECMAScript 6 reduce的递归函数。只要剩余部分太小,它就适用于大多数部分。 0已被重新定义,使其适用于[1.2,2.4,12,24]等数组。我在Chrome和IE Edge中进行了测试,因此在其他浏览器或升级中可能会有不同的表现。所以它应该使用一系列浮点数。
Array.prototype.gcd = function () {
if (this.length === 0)
return null;
return this.reduce((prev, curr) => {
if (curr <= 1.00000000001e-12)
return prev
else
return [curr, prev % curr].gcd();
});
}
var reducedValueGCD = [1.2, 2.4, 12, 24, 240].gcd();
搜索MDN减少或更多信息here。
答案 6 :(得分:0)
减少字符串分数,例如“ 2/4”,并作为字符串分数输出。
function reduce([numerator, denominator]){
for (let i = numerator; i > 0; i--) {
if(!(numerator % i) && !(denominator % i)){
return [(numerator / i), (denominator / i)];
}
}
}
function reduceFraction(string){
return reduce(string.split('/').map(n => +n)).join('/');
}
one = '2/4';
two = '20/200';
three = '330/2050';
console.log('2/4 reduced to', reduceFraction(one));
console.log('20/200 reduced to', reduceFraction(two));
console.log('330/2050 reduced to', reduceFraction(three));
答案 7 :(得分:0)
除了Jan,我还将其功能更改为:
awk
当分子> =分母时,这还将返回整数。