6174猜想:
对任意各位数字不相同的4位数,使用各位数字能组成的最大数减去能组成的最小数,对得到的差重复这个操作,最终会得到6174这个数字,并且这个操作最多不会超过7次
number = int(input('please enter a number: '))
list1 = []
list2 = []
while number != 6174:
number1 = 0
number2 = 0
list1.clear()
list2.clear()
str_number = str(number) # 将整型数据转化为字符串
for i in range(0, 4):
list1.append(int(str_number[i]))
list2.append(int(str_number[i])) # 提取数字中的每个数字
list1.sort(reverse=True) # 将数字降序排列
list2.sort(reverse=False) # 将数字升序排列
for i in range(0, 4):
number1 = number1 + list1[i] * (10**(3-i)) # 得到组成的最大数字
for i in range(0, 4):
number2 = number2 + list2[i] * (10**(3-i)) # 得到组成的最小数字
number = number1 - number2
print(f'{number1} - {number2} = {number}')
运行结果截图
程序仅用于学习交流,不做其他任何用途。
如有错误或者更好的方法,欢迎指出交流。