编写一个名为 collatz()的函数,它有一个名为 number 的参数。如果参数是偶数,那么 collatz()就打印出 number // 2,并返回该值。如果 number 是奇数,collatz()就打印并返回 3 * number + 1。然后编写一个程序,让用户输入一个整数,并不断对这个数调用 collatz(),直到函数返回值1(令人惊奇的是,这个序列对于任何整数都有效,利用这个序列,你迟早会得到 1!既使数学家也不能确定为什么。你的程序在研究所谓的“Collatz序列”,它有时候被称为“最简单的、不可能的数学问题”)。
import sys
def collatz(num):
if num % 2 == 0:
print(num // 2)
return num // 2
else:
print(3 * num + 1)
return 3 * num + 1
def main():
print("please input a number:", end='')
try:
num = int(input())
except Exception as e:
print(e)
sys.exit()
while True:
num = collatz(num)
if num == 1:
print("collatz return 1")
break;
if __name__ == '__main__':
main()