辗转相除法求最大公约数,最小公倍数。

考研过后,自己突然对机器学习感兴趣,所以就自学python语言,开始了自己的python之旅,自己现在还是菜鸟一个,希望自己可以像蜗牛一样,踏实地前行!
今天来学习一下基于python语言,采用几种方法求最大公约数,最小公倍数。
首先介绍辗转相除法的概念
设两数为a、b(a>b),用gcd(a,b)表示a,b的最大公约数,r=a (mod b) 为a除以b的余数,k为a除以b的商,即a÷b=k…….r。辗转相除法即是要证明gcd(a,b)=gcd(b,r)。
第一步:令c=gcd(a,b),则设a=mc,b=nc
第二步:根据前提可知r =a-kb=mc-knc=(m-kn)c
第三步:根据第二步结果可知c也是r的因数
第四步:可以断定m-kn与n互质(假设m-kn=xd,n=yd (d>1),则m=kn+xd=kyd+xd=(ky+x)d,则a=mc=(ky+x)cd,b=nc=ycd,则a与b的一个公约数cd>c,故c非a与b的最大公约数,与前面结论矛盾),因此c也是b与r的最大公约数。
从而可知gcd(b,r)=c,继而gcd(a,b)=gcd(b,r)。
证毕这里写链接内容。

问题:输入两个正整数,求两者的最大公约数,最小公倍数
方法一:

import datetime
start=datetime.datetime.now()#采用datetime函数计算几个方法运行的时间
#`辗转相除法求最大公约数,最小公倍数`
temp1=input('input one number:')
temp2=input('input other number:')#注意input()输入的是一个字符串,整型数字。
a=int(temp1)
b=int(temp2)
c=a*b
while b:
        a,b=b,a%b
print('最大公约数:',a)
print('最小公倍数:',c//a)
end=datetime.datetime.now()
print(end-start)

##input one number:24
input other number:9
最大公约数: 3
最小公倍数: 72
0:00:03.363582

方法二:

import datetime
start=datetime.datetime.now()
def gcd(a,b):
    if (a%b==0):
        return b
    return gcd(b,a%b)
temp1=input('input one number:')
temp2=input('input other number:')#注意input()输入的是一个字符串,整型数字。
a=int(temp1)
b=int(temp2)
print('最大公约数:',gcd(a,b))
print('最小公倍数:',a*b//gcd(a,b))
end=datetime.datetime.now()
print(end-start)
##
input one number:24
input other number:9
最大公约数: 3
最小公倍数: 72
0:00:03.272271

方法三:
这个方法是先求出最小公倍数,再求最大公约数。当两个大数输入时,程序运行比较慢。比如(1000,1001)

import datetime
start=datetime.datetime.now()
temp1=input('input one number:')
temp2=input('input other number:')#注意input()输入的是一个字符串,整型数字。
a=int(temp1)
b=int(temp2)
c=max(a,b)
d=a*b
while c%a!=0 or c%b!=0:
    c+=1
print('最小公倍数:',c)
print('最大公约数:',d//c)
end=datetime.datetime.now()
print(end-start)
##
input one number:24
input other number:9
最小公倍数: 72
最大公约数: 3
0:00:06.003796

可以看出方法一和二的程序运行时间相差无几,但是方法三就比较花时间。特别是两个大数时候。

你可能感兴趣的:([Python])