最大公约数和最小公倍数

gcd(a,b)  就是求a,b的最大公约数  

lcm(a,b)  就是求a,b的最小公倍数

 

这里讲一个公式:        a*b=gcd(a,b)*lcm(a,b)

通过这个公式,我们就可以根据gcd从而求出lcm

 

至于求gcd的算法  初中就已经介绍过了辗转相除法

LL gcd(LL a,LL b)
{
    LL t;
    while (b)
    {
        t = b;
        b = a % b;
        a = t;
    }
    return a;
}

 

也可以用递归的写法

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

 

那么 我们就可以求得 lcm = a * b / gcd(a,b)

当然这种写法可能会爆数据,推荐写成

lcm = a / gcd(a,b) * b;

 

这里给几个常用的公式:

gcd(ka, kb) = k * gcd(a, b)

lcm(ka, kb) = k * lcm(a, b)

lcm(S/a, S/b) = S/gcd(a, b)

 

参考:https://www.cnblogs.com/linyujun/p/5167914.html

全部评论

相关推荐

02-01 12:05
复旦大学 Java
腾讯的提前批大概率应该是没有笔试的,但是这个时候有相当部分的同学简历估计都没有准备好,没准备好的同学也不用急,大部分都是3月之后开,这个时候开的绝大多数都是神仙打架,问的东西也比较难,打算投递的同学也多看下计算机网络和操作系统,腾讯对这部分的知识问的比较多。另外多刷下牛客的热门题库,刷题注意刷ACM模式,和牛客的周赛题,腾讯有的部门会从这里面出原题。我是@程序员花海关注我,带你了解更多校招资讯!
程序员花海:还没有来得及准备的同学可以看下学习路线:https://www.nowcoder.com/discuss/824693499982315520?sourceSSR=users算法题:https://www.nowcoder.com/feed/main/detail/20e7a999fa04485b88340a274411ca0d?sourceSSR=users八股文:https://www.nowcoder.com/discuss/833102362771251200?sourceSSR=users简历书写方式:https://www.nowcoder.com/discuss/839907820706205696?sourceSSR=users都是以前在牛客发的文章~
软开人,秋招你打算投哪些...
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务