|
|
马上注册,结交更多好友,享用更多功能^_^
您需要 登录 才可以下载或查看,没有账号?立即注册
x
我们经常遇到的问题是给你两个数,要你求最大公约数和最小公倍数。今天我们反其道而行之,给你两个数a和b,计算出它们分别是哪两个数的最大公约数和最小公倍数。输出这两个数,小的在前,大的在后,以空格隔开。若有多组解,输出它们之和最小的那组。注:所给数据都有解,不用考虑无解的情况。
例如:a=3, b = 60
则输出:12 15
print [(str(m)+' '+str(n)) for (m,n) in [(m,n) for m in range(a,b+1) if m%a == 0 and b%m ==0 for n in range(a,b+1) if n%a ==0 and b%n == 0] if m*n == a*b and m <= n][-1]
长(chang)的想哭怎么分开来看,求大神指点
 这个叫列表推导式 这写得有点长啊 估计是为装逼:
list1 = []
for m in range(a, b+1):
if m%a == 0 and b%m == 0:
for n in range(a, b+1):
if n%a ==0 and b%n == 0:
if m*n == a*b and m <= n:
list1.append((str(m) + ' ' + str(n)))
print(list1[-1])
这样是不是好看多了?
|
|