利用辗转相除法求最大公约数:
#include <stdio.h> int hcf(int a,int b) { int r=0; while(b!=0) { r=a%b; a=b; b=r; } return(a); } int lcd(int u,int v,int h) { return(u*v/h); } int main() { int u,v,h,l; scanf("%d%d",&u,&v); h=hcf(u,v); printf("H.C.F=%d\n",h); l=lcd(u,v,h); printf("L.C.D=%d\n",l); system("pause"); }
减少代码的冗余:
int hcf(int x,int y) { return (!y) ? x : GCD(y,x%y); }
但是对于大整数会出现一些问题,换用位运算即 f(x,y)=f(x-y,y);深入考虑一下发现在算法运行的过程可能会出现x<y的情况,这时候要交换x和y,但是结果不受影响。
BigInt hcf(BigInt x,BigInt y) { if(x < y) return hcf(y,x); return (!y) ? x : hcf(x-y,y); }
代码中用到的BigInt是大整数类,可以存储成百上千位的整数,这个算法引入了另外一个问题,那就是当x和y相差很多时,算法的迭代次数会过高,导致了算法的效率较低,例如计算GCD(100000000000001,1)。这种情况确实存在啊,于是我们要考虑其他的优化了。
每种情况都有自己的适应场景,下面对以上不适合场景做一些改变:
(1)如果y=k*y1,x=k*x1.那么有f(x,y)=k*f(x1,y1)
(2)如果x=p*x2,p为素数,并且y%p != 0,那么f(x,y) = f(p*x2,y) = f(x2,y)
于是我们得到下面的解决方法:
将p = 2,
若x,y均为偶数,f(x,y) = 2*f(x/2,y/2) = 2*f(x>>1,y>>1);
若x是偶数,y是奇数,f(x,y) = f(x/2,y) = f(x>>1,y);
若x是奇数,y偶数,f(x,y) = f(x,y/2) = f(x,y>>1);
若x和y均为奇数,f(x,y) = f(y,x-y)。这时x-y一定是偶数,下一步一定会除以2。
因此,可以看出这种算法的时间复杂度是O(log2(max(x,y))。
BigInt hcf(BigInt x,BigInt y) { if(x < y) return GCD(y,x); if(y == 0) return x; else { if(IsEven(x)) { if(IsEven(y)) return (hcf(x>>1,y>>1)<<1); return hcf(x>>!,y); } else { if(IsEven(y)) return hcf(x,y>>1); return hcf(y,x-y) } } }
相关推荐
### 最大公约数与最小公倍数程序知识点详解 #### 一、背景介绍 在数学领域,特别是数论中,最大公约数(Greatest Common Divisor, GCD)和最小公倍数(Least Common Multiple, LCM)是两个非常重要的概念。最大公...
根据提供的文件信息,本文将详细解释如何使用C语言来实现最大公约数(Greatest Common Divisor, GCD)和最小公倍数(Least Common Multiple, LCM)的计算。 ### 最大公约数(GCD) #### 概念 最大公约数是指两个...
"最大公约数和最小公倍数的计算方法" 最大公约数和最小公倍数是数学中两个重要的概念,它们在算法设计、数据分析和科学计算等领域都有着广泛的应用。本文将详细介绍两种常用的计算最大公约数和最小公倍数的方法,即...
最大公约数与最小公倍数的求法。简单明了,通俗易懂,是不错的算法
此外,还涉及到找特定数的质因数分解,以及解决与最大公约数和最小公倍数相关的复杂问题,例如三个或更多数的最大公约数和最小公倍数的计算。在解决这类问题时,通常需要灵活运用上述方法,并理解它们之间的相互关系...
LCM和GCD之间存在一个关系:对于任何两个正整数a和b,它们的乘积等于两者的最大公约数与最小公倍数的乘积,即`a * b = GCD(a, b) * LCM(a, b)`。求解LCM通常可以通过已知的GCD来计算,或者直接列举出所有可能的倍数...
最大公因数与最小公倍数
用LabVIEW求最大公约数和最小公倍数。可以自行选择数据。
最大公约数、最小公倍数 * 最大公约数(a,b) * 12的因数:1、2、3、4、6、12 * 18的因数:1、2、3、6、9、18 * 12和18的最大公约数... * 两个数的积等于这两个数的的最大公约数与最小公倍数的积。即(a,b)*[a,b]=a*b
python 输入两个正整数计算最大公约数和最小公倍数 示例
在IT领域,尤其是在编程与算法的学习中,计算两个整数的最大公约数(Greatest Common Divisor,简称GCD)和最小公倍数(Least Common Multiple,简称LCM)是基础而又重要的知识点。从给定的文件标题“输出m,n的最大...
【最大公约数与最小公倍数】是小学六年级数学中的一个重要概念,涉及到数的整除性质和因数分解。最大公约数(Greatest Common Divisor, GCD)是指两个或多个非零整数共有约数中最大的一个,而最小公倍数(Least ...
4. **代数关系与最大公因数/最小公倍数**:若a=10b(a、b都是非零整数),则a是b的倍数,因此a和b的最大公因数是b,最小公倍数是a。 5. **两个数的关系**:两个数的最大公因数和最小公倍数之间存在这样的关系:两数...
最大公约数和最小倍数最大公约数和最小倍数最大公约数和最小倍数最大公约数和最小倍数最大公约数和最小倍数最大公约数和最小倍数最大公约数和最小倍数最大公约数和最小倍数最大公约数和最小倍数最大公约数和最小倍数...
在IT领域,尤其是在编程与算法设计中,求解两个数的最大公约数(Greatest Common Divisor,简称GCD)和最小公倍数(Least Common Multiple,简称LCM)是基础而重要的数学概念,广泛应用于各种计算机科学场景,如数据...
小学奥数中的最大公约数(Greatest Common Divisor, GCD)和最小公倍数(Least Common Multiple, LCM)是基础数学概念,对于培养孩子的数感和逻辑思维能力至关重要。这两个概念通常在解决实际问题时,如找共同分母、...
在计算机编程领域,最小公倍数(Least Common Multiple, LCM)和最大公约数(Greatest Common Divisor, GCD)是两个基本的数学概念,它们在算法设计和数据分析中经常被用到。C语言是一种广泛应用的编程语言,用于...
7-3 最大公约数和最小公倍数