原贴地址:http://blog.csdn.net/feixiaoxing/article/details/6991770
【 声明:版权所有,欢迎转载,请勿用于商业用途。 联系信箱:feixiaoxing @163.com】
求解最小公倍数和最大公约数是我们开始编程的时候经常需要练习的题目。从题面上看,好像我们需要求解的是两个题目,但其实就是一个题目。那就是求最大公约数?为什么呢?我们可以假想这两个数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);
- }
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;
- }
总结:
(1)看似最大公约数、最小公倍数是个小问题,但是要写好不容易,算法、参数判断、逻辑都要注意,
(2)如果m和n的数据都比较大,有没有可能利用多核降低计算的复杂度,
(3)如果m和n中有数据大于32位,那该怎么办?
(4)小问题看似简单,但是在不同的场景下却可以变得非常复杂,作为面试题可以充分考察面试者的沟通能力和应变能力。