位置: IT常识 - 正文

数字黑洞(数字黑洞有哪些)

编辑:rootadmin
一、4位数的数字黑洞 任意给定一个4位数(不能所有位都相同),比如:3278,重新组合出最大数:8732,再重新组合出最小数:2378,相减,得到新的4位数(如不足则补0),重复这个过程,最后必然得到一个数字:6174。这个现象被称为:数字黑洞。 编写一个程序,验证这个现象。 例如,给出四位数327 ...

推荐整理分享数字黑洞(数字黑洞有哪些),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:数字黑洞是什么意思,数字黑洞的原理,数字黑洞6174原理,数字黑洞一共有多少种,数字黑洞的原理,数字黑洞是什么意思,数字黑洞的原理,数字黑洞6174,内容如对您有帮助,希望把文章链接给更多的朋友!

一、4位数的数字黑洞

任意给定一个4位数(不能所有位都相同),比如:3278,重新组合出最大数:8732,再重新组合出最小数:2378,相减,得到新的4位数(如不足则补0),重复这个过程,最后必然得到一个数字:6174。这个现象被称为:数字黑洞。

编写一个程序,验证这个现象。

例如,给出四位数3278,则有验证过程如下:

8732-2378=6354

6543-3456=3087

8730-378=8352

8532-2358=6174

再如,给出四位数1011,则有验证过程如下:

1110-111=999 (不足4位,补0)

9990-999=8991

9981-1899=8082

8820-288=8532

8532-2358=6174

(1)编程思路。

编写函数void parse(int n,int *max,int *min),该函数的功能求出由整数n的四位数字组合成的最大数和最小数,分别通过形参max和min返回。

数字黑洞(数字黑洞有哪些)

在函数中,定义一个数组int a[4],用于保存整数n的4位数字,然后将数组a按从小到大的顺序排列,之后各数字顺序组成最小数,逆序组成最大数。

(2)源程序。

#include <stdio.h>void parse(int n,int *max,int *min){ int a[4],i,j,t; for (i=0; i<4; i++) { a[3-i] = n%10; n/=10; } for (i=0; i<3; i++) // 将四个数字按从小到大顺序排列 for (j=0; j<3-i; j++) if (a[j]>a[j+1]) { t = a[j+1]; a[j+1] = a[j]; a[j] = t; } t=0; for (i=0; i<4; i++) t = t * 10 + a[i] ; *min=t; t = 0; for (i=3; i>=0; i--) t= t * 10 + a[i]; *max=t;}int main(){ int n,max,min; scanf("%d",&n); do { parse(n,&max,&min); printf("%d-%d=%d\n",max,min,max-min); n=max-min; }while (n!=6174); return 0;}

二、5位数的数字黑洞

任意一个5位数,比如:12345,把它的各位数字打乱,重新排列,可以得到一个最大的数:54321,一个最小的数12345。求这两个数字的差,得:41976,把这个数字再次重复上述过程(如果不足5位,则前边补0)。如此往复,数字会落入某个循环圈(称为数字黑洞)。

例如,刚才的数12345会落入:[82962, 75933, 63954, 61974] 这个循环圈。计算过程如下:

54321 - 12345 = 41976

97641 - 14679 = 82962

98622 - 22689 = 75933

97533 - 33579 = 63954

96543 - 34569 = 61974

97641 - 14679 = 82962

[82962,75933,63954,61974]

再如,整数11211会落入:[74943,62964,71973,83952]这个循环圈。计算过程如下:

21111 - 11112 = 9999 (不足5位,则前边补0)

99990 - 9999 = 89991

99981 - 18999 = 80982

98820 - 2889 = 95931

99531 - 13599 = 85932

98532 - 23589 = 74943

97443 - 34479 = 62964

96642 - 24669 = 71973

97731 - 13779 = 83952

98532 - 23589 = 74943

[74943,62964,71973,83952]

还如,整数50000会落入:[53955,59994]这个循环圈。计算过程如下:

50000 - 5 = 49995

99954 - 45999 = 53955

95553 - 35559 = 59994

99954 - 45999 = 53955

[53955,59994]

编写一个程序,找到5位数所有可能的循环圈,并输出,每个循环圈占1行。其中5位数全都相同则循环圈为 [0],这个可以不考虑。循环圈的输出格式仿照:

[82962, 75933, 63954, 61974] 其中数字的先后顺序可以不考虑。

(1)编程思路。

如同上面4位数的数字黑洞,编写函数int next(int n) ,其功能是求5位整数n的各位数字所组成的最大数与最小数的差值,并将求得的差值作为函数值返回。

为了找出一个整数n的循环圈,编写一个函数void heidong(int n),寻找整数n的循环圈。在函数中,定义一个数组int a[20]用于保存计算过程中的每一个差值。

初始时,置a[0]=n,之后用next()函数求得n的各位数字组成的最大数与最小数的差值,保存到a[1]中,即a[1]=next(a[0]),再求 a[2]=next(a[1]),…,a[i]=next(a[i-1])。

每次求得了a[i]后,将a[i]与a[0]~a[i-1]中保存的各数依次比较,若每个a[j]==a[i](0≤j≤i-1),则找到了循环圈 a[j]~a[i-1]。输出这个循环圈。并将这个循环圈中的各个数保存到全局数组b中。

之所以要将循环圈中的数保存到全局数组中,是因为很多5位数会落在同一个循环圈中。例如,整数10000会落在[74943,62964,71973,83952]循环圈中,11112、11121、11211、…这些数同样落在这个循环圈中。这样当计算10000找到了循环圈后,将74943、62964、71973、83952这4个数保存在全局数组b中,当以后计算到11112时,找到了循环圈,由于循环圈中的数74943已在全局数组b中存在,因此这个循环圈是重复的,无需输出。这样,可以用循环

for(i=10000;i<99999;i++) { if (next(i)==0) continue; // 各位数字全部相同,忽略 heidong(i); }

找出所有5位数可能的循环圈。

(2)源程序。

#include<stdio.h>int b[12]={0}, cnt=0; // 保存各循环圈中的数避免重复,cnt为黑洞中数的个数int next(int n) // 整数n各位数字组成的最大数与最小数的差{ int a[5],i,j; for (i=0;i<5;i++) { a[i]=n%10; n/=10; } for (i=0;i<4;i++) for (j=0;j<4-i;j++) if (a[j]>a[j+1]) { int t; t=a[j]; a[j]=a[j+1]; a[j+1]=t; } int max=0,min=0; for (i=0;i<5;i++) { min=min*10+a[i]; max=max*10+a[4-i]; } return max-min;}void heidong(int n){ int a[20],flag=0; a[0]=n; int i,j,k; for (i=1; ;i++) { a[i]=next(a[i-1]); for (j=0;j<i;j++) { if(a[i]==a[j]) // a[j]~a[i-1]之间的数构成循环圈 { for (k=0;k<cnt;k++) // 看当前循环圈中的数是否保存过,本质是查重 { if(a[i]==b[k]) { flag=1; break;} } if (flag!=1) // 输出循环圈中的各数,同时保存到全局数组b中 { printf("[%d",a[j]); b[cnt++]=a[j]; for (k=j+1;k<i;k++) { printf(",%d",a[k]); b[cnt++]=a[k]; } printf("]\n"); flag=1; } } } if (flag==1) break; }}int main(){ int i; for(i=10000;i<99999;i++) { if (next(i)==0) continue; // 各位数字全部相同,忽略 heidong(i); } return 0;}

运行程序可知,所有5位数可能的循环圈有3个,如下。

[74943,62964,71973,83952][63954,61974,82962,75933][53955,59994]

本文链接地址:https://www.jiuchutong.com/zhishi/311832.html 转载请保留说明!

上一篇:织梦在高环境PHP5.4版本上存在的后台系统设置空白问题(织梦系统)

下一篇:电脑学习网教大家如何傻瓜试下载原版纯净Windows11系统,超简单傻瓜教程-OK教程(网上学电脑)

  • 高德地图怎么设置高速优先(高德地图怎么设置位置定位)

    高德地图怎么设置高速优先(高德地图怎么设置位置定位)

  • vivo NEX 3s支持扩展内存的吗(vivo nex 3s支持多少倍变焦)

    vivo NEX 3s支持扩展内存的吗(vivo nex 3s支持多少倍变焦)

  • 微信系统处于通话状态怎么关闭(微信系统处于通话)

    微信系统处于通话状态怎么关闭(微信系统处于通话)

  • 打印机连不上(打印机连不上电脑怎么解决)

    打印机连不上(打印机连不上电脑怎么解决)

  • iphone7怎么分屏操作(苹果7怎样分屏)

    iphone7怎么分屏操作(苹果7怎样分屏)

  • 群成员超过200人怎么设置(群成员超过200人怎么办)

    群成员超过200人怎么设置(群成员超过200人怎么办)

  • 电脑喇叭图标不见了怎么找出来?(电脑喇叭图标点击没反应)

    电脑喇叭图标不见了怎么找出来?(电脑喇叭图标点击没反应)

  • 层次型网状型和关系型数据库划分原则是(层次型网状型和关系型数据库划分原则是联系的复杂程度)

    层次型网状型和关系型数据库划分原则是(层次型网状型和关系型数据库划分原则是联系的复杂程度)

  • 华为麒麟芯片是自己研发的吗(华为麒麟芯片是自己生产的吗)

    华为麒麟芯片是自己研发的吗(华为麒麟芯片是自己生产的吗)

  • 电子秤按键部分失灵怎么修(电子秤上的按键)

    电子秤按键部分失灵怎么修(电子秤上的按键)

  • 电脑版微信能同步几天的记录(电脑版微信同步了以前的聊天记录会在电脑上留下记录吗)

    电脑版微信能同步几天的记录(电脑版微信同步了以前的聊天记录会在电脑上留下记录吗)

  • 如何更改工作簿的名称(如何更改工作簿名称颜色)

    如何更改工作簿的名称(如何更改工作簿名称颜色)

  • 华为通话记录保存多久(华为通话记录保存在哪里)

    华为通话记录保存多久(华为通话记录保存在哪里)

  • windows2000是不是应用软件(windows2000是什么意思)

    windows2000是不是应用软件(windows2000是什么意思)

  • 微信如何开启朋友验证功能(微信如何开启朋友圈三天可见)

    微信如何开启朋友验证功能(微信如何开启朋友圈三天可见)

  • 图像文件是什么媒体(图像文件是什么文件格式)

    图像文件是什么媒体(图像文件是什么文件格式)

  • 华为手机怎么删除软件(华为手机怎么删除桌面图标)

    华为手机怎么删除软件(华为手机怎么删除桌面图标)

  • 数据中心是指什么(数据中心是指什么意思)

    数据中心是指什么(数据中心是指什么意思)

  • 美团入住后返现怎么返(美团入住后返现怎么返60天内)

    美团入住后返现怎么返(美团入住后返现怎么返60天内)

  • vivoy93指纹在哪设置(vivoy93指纹解锁设置在哪里)

    vivoy93指纹在哪设置(vivoy93指纹解锁设置在哪里)

  • iphonexr怎么定时开关机(苹果xr怎么定时开机)

    iphonexr怎么定时开关机(苹果xr怎么定时开机)

  • vivo游戏空间有什么用(vivo游戏空间有浮窗)

    vivo游戏空间有什么用(vivo游戏空间有浮窗)

  • 抖音删了怎么恢复(抖音删了怎么恢复?)

    抖音删了怎么恢复(抖音删了怎么恢复?)

  • Win10怎么查看电脑主板型号?win10系统电脑查看主板型号的方法(win10怎么查看电池健康度)

    Win10怎么查看电脑主板型号?win10系统电脑查看主板型号的方法(win10怎么查看电池健康度)

  • 【蓝桥杯Web】第十四届蓝桥杯(Web 应用开发)模拟赛 1 期-职业院校组 | 精品题解(蓝桥杯b组2020)

    【蓝桥杯Web】第十四届蓝桥杯(Web 应用开发)模拟赛 1 期-职业院校组 | 精品题解(蓝桥杯b组2020)

  • 企业所得税的会计处理
  • 税后经营净利润加折旧与摊销
  • 资源税的税目有几个
  • 公对公打款开票
  • 缴纳印花税的会计凭证
  • 金税盘忘了清盘怎么办
  • 财务部门使用固定资产的折旧计入管理费用
  • 哪些营业外收入需要缴纳增值税
  • 预交增值税附加税费减免吗
  • 海关进口关税专用缴款书可以抵扣吗
  • 银行手续费要发票什么时候开始的
  • 个税提前预缴怎么入账?
  • 水利建设专项收入怎么计算
  • 一年过去了,特朗普减税效果如何?
  • 计提工资与发放工资
  • 出口货物免抵退申报明细录入怎么填
  • 收到红字发票后怎么做账
  • 公司退股需要交什么税
  • 费用确认条件新准则
  • 长期股权投资评估报告模板
  • 财务软件的摊销额计入管理费用
  • 公司股东转账进公司账户,会计分录
  • 商品流通会计科目
  • ntkrpamp.exe
  • 在企业扶贫捐赠活动上的讲话
  • 固定资产加速一次性扣除
  • 小规模未达起征点免税分录
  • bert获取中文词向量
  • node l
  • thinkphp 分页
  • 所有者权益变动表模板excel
  • 商品流通企业商品验收入库流程
  • 土地使用税的征税范围有哪些
  • 不计提工资直接发放可以吗
  • 把mysql移到其他盘
  • 税率开错了会影响贷款吗
  • 房地产项目转让流程
  • mysql查询时间段的交集数据
  • 可供出售金融资产的会计处理
  • 利息收入计入科目
  • 增值税直接计算法间接计算法举例
  • 支付宝提现到对公账户要收手续费吗
  • 哪些项目可以计提汇兑损益
  • 营改增后所得税怎么计算
  • 发票还没认证可以报销吗
  • 开会旅游的费用是多少
  • 小规模个人所得税税率表2023年
  • 2018城镇医疗保险缴费
  • 去年的费用怎么做分录
  • 公户的利息收入账务处理咋处理
  • 工程施工人工费,材料费,机械费占多少比例
  • 实例讲解液化滤镜瘦身
  • sql sever使用教程
  • freebsd常用命令
  • solaris newfs
  • xp系统删除文件怎么删
  • centos 安装
  • assoc.exe=exefile什么意思
  • Linux Mint Cinnamon中安装MATE桌面详细步骤
  • win10麦克风加强没有了
  • 双系统电脑怎么装系统
  • pp越狱助手下载安装苹果
  • win7工具栏怎么调整
  • win7系统电脑卡住了怎么办
  • linux如何给网卡配置ip地址
  • linux备份的文件bak如何恢复
  • 基于arcgis的python编程
  • 安卓颜色值代码表
  • unity3d脚本编程
  • js parseint parsefloat
  • dom和javascript的关系
  • linux用python
  • js domcontentloaded
  • 用python写一个程序
  • jquery有自定义选择器吗
  • 本期预缴税额怎么填
  • 天津海泰南路属于哪个区
  • 天猫主体变更是什么意思
  • 一般纳税人税务事项告知书在哪里打
  • 代理记账公司里的公司文件盒书写样式图片
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设