javascript来计算最大公约数和最小公倍数

javascript来计算最大公约数和最小公倍数

月光魔力鸭

2018-10-15 17:58 阅读 2568 喜欢 2 最大公约数 最小公倍数

最大公因数,也称最大公约数、最大公因子,指两个或多个整数共有约数中最大的一个。a,b的最大公约数记为(a,b),同样的,a,b,c的最大公约数记为(a,b,c),多个整数的最大公约数也有同样的记号。求最大公约数有多种方法,常见的有质因数分解法、短除法、辗转相除法更相减损法。与最大公约数相对应的概念是最小公倍数,a,b的最小公倍数记为[a,b]。

以上为概念,为什么讲这个问题呢?请看这里...codewars-js-刷题

下面只说几个常用的实现思路:

普通轮询

function gcd(a,b){
    var div = 1,max = Math.max(a,b),min = Math.min(a,b);
    for(let i=1;i<min;i++){
        if(max % i === 0 && min % i === 0){
            div = i;
        }
    }
    return div;
}

我们通过遍历最终获得一个最大的公约数。当然遍历顺序也可以反过来,这样步骤会相对少一部分的。

function gcd(a,b){
    var div = 1,max = Math.max(a,b),min = Math.min(a,b);
    for(let i=min;i>=1;i--){
        if(max % i === 0 && min % i === 0){
            div = i;
            break;
        }
    }
    return div;
}

辗转相除法

function gcd(a,b){
  if(b === 0)return a;
  return gcd(b,a % b);
}

通过相除然后递归获得最终的最大公约数,当然也可以简写..

const gcd= (a, b) => b ? gcd(b, a % b) : a;

辗转相减法

function gcd(a,b){
    var p = Math.abs(a - b ),min = Math.min(a,b);
    if(min % p === 0)return p;
    return gcd(min,p);
}

以上三种方式可以通过js来获得两个数的最大公约数。当我们有了最大公约数后,就可以通过最大公约数获得两个数的最小公倍数。

[a,b] = a * b / (a,b)
a 与 b的最小公倍数等于 a与b的乘积 除以 a与 b的最大公约数。

最小公倍数

const gcd = (a, b) => b ? gcd(b, a % b) : a;//获得ab 的最大公约数
const lcm = (a, b) => a * b / gcd(a, b);//获得ab的最小公倍数

顺便,这里再贴下关于这道题的解法:

const gcd = (a, b) => b ? gcd(b, a % b) : a;
const lcm = (a, b) => a * b / gcd(a, b);

function convertFrac(arr) {
  const cd = arr.reduce((a, [_, d]) => lcm(d, a), 1);
  return arr.map(([n, d]) => `(${n * cd/d},${cd})`).join('');
}
//声明下,这个解法并不是我的。

以上为通过js来计算两个数的最大公约数和最小公倍数的实现方式。

转载请注明出处: https://chrunlee.cn/article/js-common-denominators.html


感谢支持!

赞赏支持
提交评论
评论信息 (请文明评论)
暂无评论,快来快来写想法...
推荐
jsQR 是一款纯粹的由javascript实现的二维码识别库,可以在浏览器端使用,也可以在后端node.js环境使用。我之前使用过其他的识别库,例如:qrcode-reader 或其他,在使用上都比较麻烦,而且识别率并不高。jsQR是后来发现的,感觉(没有实际对比验证)jsQR识别率要更高些,使用起来也更简单,不需要安装其他依赖软件。
在我们通过canvs画图的时候经常会用到圆,且需要计算出圆上某点的坐标,由于我数学没学好,总是记不得怎么获取,这里记录下,加深记忆
java 对象中有很多引用,甚至会出现循环引用,比如 user 对象中有 school 对象,school 对象中又有 user 对象,这样在对 user 对象序列化的时候,就会出现死循环,导致内存溢出。通过一定的方式,将每个对象增加ID 和 REF 引用标识最终可以解决这个问题
在开发过程中多个页面使用的一个小工具类,简单完善了下,还算不错,给各位提供下小思路。
今天刷codewars的题目的时候碰到一个通过js来实现字符串转base64的题目,base64虽然在js或nodejs中经常用,但是我还真没有仔细去看过原理以及如何实现,这回绕不过去了,赶紧找了找资料看了下。
偶尔练习下canvas,这里简单记录下常用API,防止遗忘..加深记忆..努力提高..争取突破...daydayup
codewars上的一个题目,这里记录下解决方法。
最近做个nodejs的项目,使用了thinkjs 3.0 的框架,编辑器为vs code ,之前用的好好的,每次 . 后都有提示的,可是使用了多模块后发现.. model的提示没有了..