美文网首页Web 前端开发 让前端飞
【Javascript】计算两数之间所有整数的最小公倍数

【Javascript】计算两数之间所有整数的最小公倍数

作者: 雨水之后 | 来源:发表于2017-11-30 09:33 被阅读0次
function smallestCommons(arr) {

  var range = [];

  //从大到小排列
  arr.sort(function(a,b){return b-a;});

  for(var i=arr[0];i>=arr[1];i--){
    range.push(i);
  }

  //最小公倍数 = 数列乘积 / 最大公约数
  var lcm = range[0];

  for(var j=1;j<range.length;j++){
    var GCD = gcd(lcm, range[j]);
    lcm = (lcm * range[j]) / GCD;
  }

  return lcm;

  //欧几里德算法求最大公约数
  function gcd(x, y) {
    if (y === 0)
        return x;
    else
        return gcd(y, x%y);
  }

}

THE END.

相关文章

网友评论

    本文标题:【Javascript】计算两数之间所有整数的最小公倍数

    本文链接:https://www.haomeiwen.com/subject/pcgmbxtx.html