문제는 두
파라미터라는 번호를 갖는 함수라는 collatz ()를 작성한다. 인수가 다음 짝수, Collatz 인 경우 () 수 // 2를 인쇄하고, 값을 반환합니다. 개수가 홀수 인 경우 collatz ()는 인쇄 * 3 + 번호 1을 반환한다. 그런 다음이 순서를 사용, 1 (값이 놀랍게도,이 순서는 정수 유효 함수가 반환 될 때까지, 사용자가 정수를 입력하고이 번호 collatz ()를 호출 계속 할 수있는 프로그램을 작성, 당신은 조만간 1을 얻을 것이다 ! 심지어 수학자 이유를 확인할 수 없습니다. 프로그램을 소위의 연구에서 "Collatz 시퀀스,"때때로) "가장 간단한 불가능 수학 문제"라고합니다.
def collatz(number):#定义函数
try:
new_num=int(number)#判断num是否为正整数
except:
print('请输入正整数')#显示出错原因
else:
new_num=new_num%2#偶数余数为0,其他为奇数
if not new_num: #偶数
number=int(number)//2
else:#奇数
number=int(number)*3+1
print(number)
return number
# number=input('输入整数')
# nex=collatz(number)#初始赋值
#判断nex是否为整数并且不等于0
# if isinstance(nex,int)and int(number) != 0:
# while nex !=1:
# nex=collatz(nex)#循环赋值