博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
一步一步写算法(之 最大公约数、最小公倍数)
阅读量:5996 次
发布时间:2019-06-20

本文共 1211 字,大约阅读时间需要 4 分钟。

原文:

【 声明:版权所有,欢迎转载,请勿用于商业用途。  联系信箱: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);}
    下面就可以开始最大公约数的求解。其实,关于最大公约数的求解,大家看到的更多是各种捷径,比如说 。欧几里得法构思十分巧妙,它利用了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)小问题看似简单,但是在不同的场景下却可以变得非常复杂,作为面试题可以充分考察面试者的沟通能力和应变能力。

你可能感兴趣的文章
获取用户的真实ip
查看>>
不同平台的线程并发接口对比
查看>>
在Ubuntu14.4(32位)中配置I.MX6的QT编译环境
查看>>
BZOJ 3530: [Sdoi2014]数数 [AC自动机 数位DP]
查看>>
墨卡托投影、高斯-克吕格投影、UTM投影及我国分带方法
查看>>
Android中通过反射来设置Toast的显示时间
查看>>
Vysor Pro破解助手
查看>>
翻译Beginning iOS 7 Development中文版
查看>>
理顺FFT
查看>>
003-spring结合java类调用quartz
查看>>
Idea 常用功能汇总,工作中常用技巧,移出请说明原因,笔记花了好长时间汇总的...
查看>>
php给图片加入文字水印
查看>>
iOS开发-sqlite3使用
查看>>
(5)QlikView中的RowNo()函数
查看>>
SiteMesh2-示例工程
查看>>
poj 1087 A Plug for UNIX 【最大流】
查看>>
Phoenix与Squirrel 是什么?
查看>>
Photoshop制作的ico图标方法
查看>>
HDU 1241 Oil Deposits (DFS)
查看>>
【翻译自mos文章】注意: ASMB process exiting due to lack of ASM file activity
查看>>