6174猜想的证明 Python

什么是6174猜想

        1955年,卡普耶卡(D.R.Kaprekar)研究了对四位数的一种变换:任给出四位数k0,用它的四个数字由大到小重新排列成一个四位数m,再减去它的反序数rev(m),得出数k1=m-rev(m),然后,继续对k1重复上述变换,得数k2.如此进行下去,卡普耶卡发现,无论k0是多大的四位数,只要四个数字不全相同,最多进行7次上述变换,就会出现四位数6174。

以1234为例

第一次变换:4321-1234=3087

第二次变换:8730-378=8352

第三次变换:8532-2358=6174          符合6174猜想

代码证明

代码一:

def DRK(lst):for i in range(7):num1=int(''.join(map(str,sorted(lst))))num2=int(''.join(map(str,sorted(lst,reverse=True))))num3=num2-num1lst=sorted(str(num3))if num3==6174:return Truereturn False#使用for循环进行排列组合
for a in range(1,10):for b in [k for k in range(0,10) if k!=a]:for c in [k for k in range(0,10) if (k!=a and k!=b)]:for d in [k for k in range(0,10) if (k!=a and k!=b and k != c)]:if DRK == False:print('结论不成立!')exit()
print('结论成立。')

用for循环遍历来组合会有很多组合重复被选中,比如1234这个四位数就有多种选法:【1,2,3,4】、【2,1,3,4】、【3,1,2,4】、【4,1,2,3】等等。

别急,咱还有第二套方案!

代码二:

from itertools import *def DRK(lst):for i in range(7):num1=int(''.join(map(str,sorted(lst))))num2=int(''.join(map(str,sorted(lst,reverse=True))))num3=num2-num1lst=sorted(str(num3))if num3==6174:return Truereturn Falselst=[k for k in range(10)]
#使用itertools库中的combinations()函数进行组合
for i in combinations(lst,4):if DRK(list(i))==False:print('结论不成立!')exit()    #有一个不成立的就直接退出循环print('结论成立。')

两个代码的效率比较

 可见代码二明显优于代码一

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.rhkb.cn/news/30689.html

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

程序员的数学课04 万物可数学,经典公式是如何在生活中应用的?

在我们的生活和工作中,有大量的数学应用场景,一些简单的经典公式会在我们的生活中被反复验证、体现。对于经典公式的理解,能增强你的数据 sense,更能帮助你在遇到问题时,迅速找到解决思路。 这一课时我将列举四个脑洞…

评审8年终获发表,数学天才望月新一证明abc猜想,全球只有十几个数学家读懂但争议未消...

晓查 发自 凹非寺 量子位 报道 | 公众号 QbitAI abc猜想,数学界悬而未决的重要猜想,它的证明过程经过8年的同行评审,终于要在期刊上发表了。 论文作者是日本的天才数学家望月新一,他33岁起就在京都大学担任数学教授。 这一次望月新…

C++角谷猜想

题目描述: 请编写一个程序,验证角谷猜想。所谓角谷猜想是:“对于任意大于1的自然数n,若n为奇数,则将n变为3*n1,否则将n变为n的一半。”经过若干次这样的变化,一定会使n变为1。 输入格式&#…

某安网别逆向,一不小心就......

​ 大家好,我是TheWeiJun,欢迎来到我的公众号。在现代互联网中,cookie成为了网站管理的重要工具。某些网站会对cookie进行加密,以加强数据的安全性和保密性。然而,逆向加密算法并不是一件简单的事情。本文将探讨如何逆…

群晖docker实现IPV6访问

概述: 群晖docker默认没有没有开启ipv6,需要修改docker的配置文件。 修改过程: 一、首先确认自己的网络已经支持IPV6(需要光猫及路由器支持ipv6) 1.登陆www.test-ipv6.com查看是否已经接入IPV6 2.登陆自己的群晖查…

群晖传文件到服务器,文件上传到群晖服务器

文件上传到群晖服务器 内容精选 换一换 监控数据上报功能可以将系统中采集到的监控数据写入到文本文件,并以FTP或SFTP的形式上传到指定的服务器中。使用该功能前,管理员需要在FusionInsight Manager页面进行相关配置。“监控数据上传”默认为不启用&…

群晖硬盘警告修复

群晖硬盘警告修复 为了更好的浏览体验,欢迎光顾勤奋的凯尔森同学个人博客http://www.huerpu.cc:7000 我的群晖每次被我拿出来的时候,由于震动等原因,会时不时出现硬盘警告的提示,从而导致无法使用,现在我们来屏蔽一下…

安装群晖显示服务器忙,云服务器安装群晖

云服务器安装群晖 内容精选 换一换 华为云帮助中心,为用户提供产品简介、价格说明、购买指南、用户指南、API参考、最佳实践、常见问题、视频帮助等技术文档,帮助您快速上手使用华为云服务。 登录Windows操作系统的弹性云服务器时,需使用密码方式登录。因此,用户需先根据创…

群晖php mysql网站博客,群晖建博客详细教程

群晖建博客详细教程 2017-03-01 14:23:01 36点赞 419收藏 44评论 小编注:此篇文章来自即可瓜分10万金币,周边好礼达标就有,邀新任务奖励无上限,点击查看活动详情 群晖NAS功能强大,除了大家都知道的存储文件,代替各种公有云以外,还可以当成一个网站服务器来使用。配合DDN…

群晖web文件服务器docker,群晖docker搭建数据库服务器

群晖docker搭建数据库服务器 内容精选 换一换 本手册基于华为云关系型数据库实践所编写,用于指导您完成相关设置,购买更符合业务的数据库实例。 创建一个外部服务器。外部服务器是存储OBS服务器信息或其他同构集群信息的载体。默认只有系统管理员才可以创建外部服务器,否则需…

群晖系统ftp服务器,群晖对接云服务器ftp

群晖对接云服务器ftp 内容精选 换一换 用户可以在MRS Manager界面上配置监控指标数据对接参数,使集群内各监控指标数据通过FTP或SFTP协议保存到指定的FTP服务器,与第三方系统进行对接。FTP协议未加密数据可能存在安全风险,建议使用SFTP。MRS Manager支持采集当前管理的集群内…

群晖服务器+微信同步,群晖服务器 云同步

群晖服务器 云同步 内容精选 换一换 集群中的每一个节点对应一台弹性云服务器或物理机,集群节点创建成功后,您仍可以根据需求,修改云服务器的名称或变更规格。CCE节点的部分信息是独立于弹性云服务器ECS维护的,当您在ECS控制台中修改云服务的名称、弹性公网IP,以及变更计费…

群晖使用心得

近期采购了群晖的DS920和DS220,又对比了DS420J和DS220J,总结出一些心得体会: 1、群晖的操作系统是嵌入式Linux(DSM),支持x86和ARM 两种架构,安装ipkg或opkg,再安装一些常用软件就能…

群晖DS218+部署GitLab

欢迎访问我的GitHub https://github.com/zq2599/blog_demos 内容:所有原创文章分类汇总及配套源码,涉及Java、Docker、Kubernetes、DevOPS等; 起因是懒 最近开始折腾GitLab的CI功能,就打算在家部署一个GitLab,通常做…

群晖安装aria2

下载镜像:oldiy-aria2-ui-ng1 新建文件夹:aria2 -conf 设置rpc密钥,之前环境变量里面设置的secret 设置bt服务器地址 https://edam.top/tk/ 最后,需要一个热门的文件来下载,我这边使用的是【ubuntu-21.10-desktop-amd…

虚拟机安装群晖

1.准备文件 下载链接 群晖助手、群晖pat文件、虚拟机文件 2.记事本编辑虚拟机vmx文件 修改版本号与虚拟机版本一致 3.双击vmx文件 选择虚拟机 右键设置参数如图 4.安装群晖助手 启动虚拟机打开助手 搜索联机 等待加载 点击安装 选择pat 等待安装 配置账号信息登录

CentOS7设置登录次数限制

最近我的1核2G服务器居然都被人盯上了(逃 每天都有大量登录失败的记录,防止被暴力破解,修改了ssh默认的22端口,结果还是被人扫描出了修改后的端口。遂添加如下登录次数限制。 使用系统版本:CentOS7.6 修改文件&#…

金蝶K3WISE V14.0注册方法

金蝶K3WISE V14.0破解注册码,安全可靠,使用稳定。K3 WISE的最后一个离线版本。也是最稳定的版本。欢迎联系,联系方式见下图。 经常长期测试,该版本可以使用。 正版K3WISE,价格在几万-几十万,如果你使用破解…

PyTorch中的Element-wise operations

1. What does element-wise mean? 逐个元素操作是两个tensor之间的操作,该操作在相应tensor内的对应元素上进行, t1和t2中的1和9就是tensor中的对应元素。 加法是按element-wise进行的运算,实际上,所有算术运算(加,减,乘和除)都是按逐个元素进行的运算。 标量值是Ran…