Итак, я пишу программу на Python, чтобы получить GCD любого количества чисел.
def GCD(numbers):
if numbers[-1] == 0:
return numbers[0]
# i'm stuck here, this is wrong
for i in range(len(numbers)-1):
print GCD([numbers[i+1], numbers[i] % numbers[i+1]])
print GCD(30, 40, 36)
Функция принимает список чисел. Это должно печатать 2. Однако я не понимаю, как использовать алгоритм рекурсивно, чтобы он мог обрабатывать несколько чисел. Может кто-нибудь объяснить?
обновлено, все еще не работает:
def GCD(numbers):
if numbers[-1] == 0:
return numbers[0]
gcd = 0
for i in range(len(numbers)):
gcd = GCD([numbers[i+1], numbers[i] % numbers[i+1]])
gcdtemp = GCD([gcd, numbers[i+2]])
gcd = gcdtemp
return gcd
Хорошо, решил это
def GCD(a, b):
if b == 0:
return a
else:
return GCD(b, a % b)
а затем используйте сокращение, например
reduce(GCD, (30, 40, 36))