五位数数字黑洞编程.doc

上传人:yyf 文档编号:8679042 上传时间:2020-12-19 格式:DOC 页数:3 大小:15.50KB
返回 下载 相关 举报
五位数数字黑洞编程.doc_第1页
第1页 / 共3页
五位数数字黑洞编程.doc_第2页
第2页 / 共3页
五位数数字黑洞编程.doc_第3页
第3页 / 共3页
亲,该文档总共3页,全部预览完了,如果喜欢就下载吧!
资源描述

《五位数数字黑洞编程.doc》由会员分享,可在线阅读,更多相关《五位数数字黑洞编程.doc(3页珍藏版)》请在三一文库上搜索。

1、.五位数数字黑洞编程马二老师工作室任意一个5位数,比如:34256,把它的各位数字打乱,重新排列,可以得到一个最大的数:65432,一个最小的数23456。求这两个数字的差,得:41976,把这个数字再次重复上述过程(如果不足5位,则前边补0)。如此往复,数字会落入某个循环圈(称为数字黑洞)。比如,刚才的数字会落入:82962, 75933, 63954, 61974 这个循环圈。请编写程序,找到5位数所有可能的循环圈,并输出,每个循环圈占1行。其中5位数全都相同则循环圈为 0,这个可以不考虑。循环圈的输出格式仿照:82962, 75933, 63954, 61974其中数字的先后顺序可以不考

2、虑。#includefenjie(int x,int *a);zuhe(int *a,int *b);main()int a20,zu2,fen5,count,n,m,i,j,s,z;/*数组fen用来分解各个位数字,zu用来重新组合大小数,m为所求差,a用来存放数差,n为输入的五位数,conut位控制项数。*/bool bb=true;/*对循环进行控制的变量。为假值时,输出完毕,不在循环,*/printf(输入一个五位数:n);scanf(%d,&n);fenjie(n,fen);/执行函数分解位数zuhe(fen,zu);/执行函数组合大小for(i=0;i20;i+)m=zu0-zu1

3、;if(m=0)printf(0n);break;ai=m;fenjie(m,fen);zuhe(fen,zu);for(j=0;bb&ji;j+)if(ai=aj)/判断相等的数,有,则顺序输出。s=i;z=j;printf();for(int k=j;ki;k+)printf(+count%4=0?%dn:%d, ,ak);/*输出每个循环数*/精品.bb=false;fenjie(int x,int *a)/函数用来分解各个位数int k,i;for(k=100000,i=0;i5;i+)ai=x%k/(k/10);k/=10;zuhe(int *a,int *b)/函数用来组合最大与最小数int i,j,k,t;b0=0;b1=0;for(i=0;i5;i+)for(j=0;ji;j+)if(aiaj)/对数组中的书进行排列t=ai;ai=aj;aj=t;for(k=1,i=0;k=10000;k*=10,i+)b0+=ai*k;/求出最大的数for(k=1,i=4;k=10000;k*=10,i-)b1+=ai*k;/求出最小的数如有侵权请联系告知删除,感谢你们的配合!精品

展开阅读全文
相关资源
猜你喜欢
相关搜索

当前位置:首页 > 科普知识


经营许可证编号:宁ICP备18001539号-1