Python collatz序列
编写一个名为collatz()的函数,它有一个名为number 的参数。如果参数是偶数,那么collatz()就打印出number // 2,并返回该值。如果number 是奇数,collatz()就打印并返回3 * number + 1。
然后编写一个程序,让用户输入一个整数,并不断对这个数调用collatz(),直到函数返回值1(令人惊奇的是,这个序列对于任何整数都有效,利用这个序列,你迟早会得到1!既使数学家也不能确定为什么。你的程序在研究所谓的<br>“Collatz序列”,它有时候被称为“最简单的、不可能的数学问题”)。
答案1:
def collatz(num):
if num % 2 == 0:
return num//2
elif num % 2 == 1:
return 3*number +1
try:
print("请输入数字:")
number = int(input())
while True:
number = collatz(number)
print(number)
if number == 1:
break
except ValueError:
print("请输入整数")
答案2:
print("This is The Collatz Sequence")
user = int(input("Enter a number: "))
def collatz(n):
print(n)
while n != 1:
if n % 2 == 0:
n = n // 2
print(n)
else:
n = n * 3 + 1
print(n)
collatz(user)
答案3:
def collatz(number):
if number % 2 == 0:
return number // 2
elif number % 2 == 1:
return 3 * number + 1
chosenInt = int(input('Enter an integer greater than 1: '))
print(chosenInt)
while chosenInt != 1:
chosenInt = collatz(chosenInt)
print(chosenInt)
本作品采用 知识共享署名-相同方式共享 4.0 国际许可协议 进行许可。
写的很好,支持一下
边学 边记录