Python验证6174猜想

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}')
    

运行结果截图
在这里插入图片描述
程序仅用于学习交流,不做其他任何用途。
如有错误或者更好的方法,欢迎指出交流。

  • 0
    点赞
  • 13
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值