加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

C++算法之求最大公约数和最小公倍数

发布时间:2020-12-16 07:44:23 所属栏目:百科 来源:网络整理
导读:今天PHP站长网 52php.cn把收集自互联网的代码分享给大家,仅供参考。 求解最小公倍数和最大公约数是我们开始编程的时候经常需要练习的题目。从题面上看,好像我们需要求解的是两个题目,但其实就是一个题目。那就是求最大

以下代码由PHP站长网 52php.cn收集自互联网

现在PHP站长网小编把它分享给大家,仅供参考

求解最小公倍数和最大公约数是我们开始编程的时候经常需要练习的题目。从题面上看,好像我们需要求解的是两个题目,但其实就是一个题目。那就是求最大公约数?为什么呢?我们可以假想这两个数m和n,假设m和n的最大公约数是a。
那么我们可以这样写:
????m?=?b?*a;
????n?=?c?*?a;
????所以m和n的最小公倍数就应该是a*b*c啊,那不就是m?*?n?/?a,其中m和n是已知的,而a就是那个需要求解的最大公约数。所以就有了下面的代码,
int GetMinCommonMultiple(int m,int n)  
{  
    assert(m && n);  
  
    return m * n / GetMaxCommonDivide(m,n);  
}  
????下面就可以开始最大公约数的求解。其实,关于最大公约数的求解,大家看到的更多是各种捷径,比如说欧几里得法。欧几里得法构思十分巧妙,它利用了m、n和n、m%n之间的最大公约数是相等的这一重要条件,充分利用替换的方法,在?m%n等于0的那一刹那,获得我们的最大公约数。然而,我们平时自己所能想到的方法却不多,下面的方法就是具有典型意义的一种:
????a)?首先对数据m和n判断大小,小的赋值给smaller,大的赋值给larger
????b)index索引从2开始到smaller遍历,发现有没有数据可以同时被两者整除,有则更新数据
????c)循环结束后,获取最大的公约数
int GetMaxCommonDivide(int n,int m)  
{  
    int index;  
    int smaller;  
    int larger;  
    int value;  
    assert(n && m);  
  
    if(n > m){  
        larger = n;  
        smaller = m;  
    }else{  
        larger = m;  
        smaller = n;  
    }  
  
    value = 1;  
    for(index = 2; index <= smaller; index++){  
        if(0 == (smaller % index) && 0 == (larger % index))  
            value = index;  
    }  
  
    return value;  
}  

 
????上面的代码看似没有问题,但是还是留下了一个遗憾,如果m和n的数据都大于32位,那怎么办?也许有的朋友会说,现在有64位的cpu。但是如果我们此刻没有64位的cpu,那该怎么办呢?

总结:
????(1)看似最大公约数、最小公倍数是个小问题,但是要写好不容易,算法、参数判断、逻辑都要注意,
????(2)如果m和n的数据都比较大,有没有可能利用多核降低计算的复杂度,
????(3)如果m和n中有数据大于32位,那该怎么办?
????(4)小问题看似简单,但是在不同的场景下却可以变得非常复杂,作为面试题可以充分考察面试者的沟通能力和应变能力。

以上内容由PHP站长网【52php.cn】收集整理供大家参考研究

如果以上内容对您有帮助,欢迎收藏、点赞、推荐、分享。

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读