当前位置: 首页 > news >正文

Kaprekar 7641 - 1467= 6174

package homework;import java.util.Arrays;import util.StringUtil;/*** 
数学黑洞数6174,即卡普雷卡尔(Kaprekar)常数,
它的算法如下:
取任意一个4位数(4个数字均为同一个数的除外),
将该数的4个数字重新组合,形成可能的最大数和可能的最小数,再即将两者之间的差求出来;
对此差值重复同样过程,最后总是到达卡普雷卡尔黑洞6174,到达这个黑洞最多需要7个步骤.
例如:取1、2、3、4这4个数
大数:取这4个数字能构成的最大数,本例为4321;
小数:取这4个数字能构成的最小数,本例为:1234;
差:求出大数与小数之差,本例为:4321-1234=3087;
重复:对新数3087按以上算法求得新数为8730-0378=8352;
重复:对新数8352按以上算法求得新数为8532-2358=6174;
结论:对任何只要不是4位数字全相同的4位数,按上述算法,不超过7次激素,最终结果多无法逃出6174黑洞.
从文本框Text1中输入一个任意的数字不完全相同的四位正整数,在文本框Text2中输出掉进黑洞的步骤次数.** Kaprekar 7641 - 1467= 6174** @author ZengWenFeng* @date 2023.11.03* @email 117791303@qq.com* @mobile 13805029595*/
public class Math_2023_11_03_Kaprekar
{public Math_2023_11_03_Kaprekar(){}public static String calc(String num){if (num == null || num.length() != 4){return "-1";}char[] arrChar = num.toCharArray();Arrays.sort(arrChar);System.out.println(arrChar);String strMin = new String(arrChar);System.out.println("strMin : " + strMin);String strMax = new StringBuilder(strMin).reverse().toString();System.out.println("strMax : " + strMax);int min = Integer.parseInt(strMin);int max = Integer.parseInt(strMax);int result = max - min;System.out.println(" max - min = " + strMax + " - " + strMin + " = " + result);if (result == 0){return "0";}else{String strResult = Integer.toString(result);// 不足四位数,补前导“0”if (strResult.length() <= 4){return StringUtil.getZeroStr(4 - strResult.length()) + strResult;}//else{return strResult;}}}public static void main(String[] args){String num = "888823";System.out.println(num);int cnt = 0;while (true){String temp = calc(num);cnt++;if (temp.equals("6174")){calc(temp);break;}else if (temp.equals("0")){System.err.println("输入值[" + num +  "]不能是4位相同数!");break;}else if (temp.equals("-1")){System.err.println("输入值[" + num +  "]不是四位数!");break;}else{num = temp;}}System.out.println("cnt : " + cnt);}}

2023.11.03 homework-CSDN博客

http://www.lryc.cn/news/216795.html

相关文章:

  • 李宏毅机器学习笔记.Flow-based Generative Model(补)
  • Java使用Spark入门级非常详细的总结
  • kubernetes集群编排——k8s存储
  • 【软件STM32cubeIDE下H73xx配置串口uart1+中断接收/DMA收发+HAL库+简单数据解析-基础样例】
  • jdk8和jdk9中接口的新特性
  • 1-爬虫-requests模块快速使用,携带请求参数,url 编码和解码,携带请求头,发送post请求,携带cookie,响应对象, 高级用法
  • java商城免费搭建 VR全景商城 saas商城 b2b2c商城 o2o商城 积分商城 秒杀商城 拼团商城 分销商城 短视频商城
  • 【TS篇一】TypeScript介绍、使用场景、环境搭建、类和接口
  • Tuna: Instruction Tuning using Feedback from Large Language Models
  • uni-app 应对微信小程序最新隐私协议接口要求的处理方法
  • PostgreSQL 进阶 - 使用foreign key,使用 subqueries 插入,inner joins,outer joins
  • 【Python 千题 —— 基础篇】地板除计算
  • 【随手记】np.random.choice()函数
  • 2003-2022年地级市-财政收支明细数据(企业、个人所得税、科学、教育、医疗等)
  • 影响服务器正常使用的有哪些因素
  • NLP学习笔记:使用 Python 进行NLTK
  • 突破性技术!开源多模态模型—MiniGPT-5
  • IntelliJ IDEA快捷键sout不生效
  • 用C++QT实现一个modbus rtu通讯程序框架
  • Python如何设置下载第三方软件包的国内镜像站服务器的地址
  • ChatGLM3-6B详细安装过程记录(Linux)
  • python的类
  • 前端 用HTML,CSS, JS 写一个简易的音乐播放器
  • 自定义QChartView实现鼠标放在图表时,显示鼠标位置坐标值(x,y)
  • antv/g6 交互与事件及自定义Behavior
  • MongoDB根据时间范围查询
  • 大数据Doris(十五):Doris表的字段类型
  • 文本批量处理,一键转换HTML文件编码,释放您的繁琐工作!
  • 硬件工程师到底可以从哪些方面提升自己?
  • 论文辅助笔记:t2vec models.py