版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
1、摘要卡布列克运算是指给定任意一个四位整数N(N>0),其各位数字不完全相同。这个数必有这样的规律:1)把组成N的四个数字从小到大排列,构成最小四位数min;2)把组成N的四个数字从大到小排列,构成最大四位数ma3)然后求max与min之差,得到一个新的四位数;把新的四位数重复以上过程,最后总能得到结果:6174该验证过程采用面向对象方法,将数学和编程相结合,再通过构建对象数组来完成。关键词:卡不列克运算、验证、面向对象、对象数组2设计方案2.1整体设计方案输入(1个4位数)检查输入获取各个数位并排序验证过程生成最小四位数min最大四位数maxmax与min之差重复以上流程直到结果为617
2、42.1.1输入检查输入要求各位不完全相同的4位数boolkabulek二isAcceptable(intn)if(n<1000)returnfalse;if(n>=10000)returnfalseintarr4;for(inti=0;i!=4;i+)arri=n%10;n/=10;for(inti=0;i!=3;i+)for(intj=i+1;j!=4;j+)获取各个数位并排序相关头文件cstdlib.hkabulek.hvoidkabulek二setsort(intn)for(inti=0;i!=4;i+)nnnni=n%10;n/=10;std:sort(nnnn,nnnn
3、+4);生成最小四位数min最大四位数maxintkabulek二minForm()intn=0;for(inti=0;i!=4;i+)n*=10;n+=nnnni;returnn;intkabulek二maxForm()intn=0;for(inti=3;i>=0;i-)|n*=10;n+=nnnni;returnn;验证过程voidkabulek二showStep(intn)std:cout<<maxForm()<<"-"<<std:setw(4)<<std:setfill('0')<<m
4、inForm()<<"="<<n<<std:endl;voidkabulek二verify。if(hasAccepted=false)std:cout<<"未接受数字!"<<std:endl;return;=std:cout<<"num:"<<num<<std:endl;this->setsort(num);intn=maxForm()-minForm();this->showStep(n);while(n!=6174)this
5、->setsort(n);n=maxForm()-minForm();this->showStep(n);std:cout<<"检验完毕"<<std:endl;2.1.2验证过程voidmain()intcount=0;kabulekk10000;/建立对象数组for(inti=1;i!=10000;i+)ki.setNum(i);ki.verify();return;3.程序演示:SBC:Windowssystem32cmd.exeii|请按任意键继续C:Windowssystem32cmd.exe,443-3447=3996963-3
6、699=6264642-2466=41761641-1467-6174检验完毕1027请按任意键继续.num:10277210-0127=70838730-0378=83528532-2358=6174检险完毕1028请按任意键继续nun:10288210-0128=80823»20-028»8532B532-235R=6174检验完毕102931结论无论学习什么,亲自动手去做了才能得到最深刻的体会。附录代码kabulek.h#pragmaonceclasskabulek/要验证的数字intnum;/十进制位intnnnn4;/是否接受到一个符合要求的数字boolhasAc
7、cepted;public:/默认构造函数kabulek();kabulek(int);kabulek();/验证voidverify();/静态函数isAcceptabble判断是否符合要求staticboolisAcceptable(int);/numsettervoidsetNum(intn);private:构成最小四位数intminForm();构成最大四位数intmaxForm();/求取一个4位数的各位并排序voidsetsort(intn);/输出验证的每一次步骤voidshowStep(int);kabulek.cpp#include"kabulek.h"
8、#includealgorithm#include<iostream>#include<iomanip>voidkabulek二setsort(intn)'for(inti=0;i!=4;i+)nnnni=n%10;n/=10;std:sort(nnnn,nnnn+4);kabulek二kabulek()hasAccepted=falsekabulek二kabulek(intn):num(n)hasAccepted=isAcceptable(n);if(!hasAccepted)return;this->setsort(n);kabulek:kabulek
9、()voidkabulek二showStep(intn)std:cout<<std:setw(4)<<std:setfill('0')<<maxForm()<<"-"<<std:setw(4)<<std:setfill('0')<<minForm()<<"="<<n<<std:endl;voidkabulek二verify。if(hasAccepted=false)std:cout<<&quo
10、t;未接受数字!"<<std:endl;return;std:cout<<"num:"<<num<<std:endl;this->setsort(num);intn=maxForm()-minForm();this->showStep(n);while(n!=6174)this->setsort(n);n=maxForm()-minForm();this->showStep(n);std:cout<<"检验完毕"<<std:endl;boolkabulek二isAcceptable(intn)if(n<1000)returnfalse;if(n>=10000)returnfalse;intarr4;for(inti=0;i!=4;i+)arri=n%10;n/=10;for(inti=0;i!=3;i+)for(intj=i+1;j!=4;j+)if(arri!=arrj)returntrue;二returnfalse;voidkabulek二setNum(intn)std:cout<<n<<std:endl;system("Pause");hasAcc
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 助力大桥施工方案(3篇)
- 如何培训施工方案(3篇)
- 碾压地基施工方案(3篇)
- 吴忠地坪施工方案(3篇)
- 乡村篝火活动策划方案(3篇)
- 体验方案项目流程
- 2025年大学(林学)森林生态学阶段试题及答案
- DB64-T 992.4-2014 电梯运行安全监测信息管理系统技术规范 第4部分:数据格式、编码规则与通讯协议
- 2025年大学(会计学)审计学综合测试卷及解析
- JJF(蒙) 115-2025 全自动比表面积分析仪校准规范
- 机房用电安全管理培训课件
- 2026年中文投(陕西)文化传媒有限公司招聘备考题库完整参考答案详解
- 2026秋招:华夏银行笔试题及答案
- 2025年上海农林职业技术学院马克思主义基本原理概论期末考试模拟题附答案
- 2025 小学六年级语文下册 日积月累 经典名句情境应用课件
- 2025年精麻药品考试试题附答案
- 楼电梯维保及故障修复指南
- 2025河南省公务员考试《公共基础知识》题库及答案1套
- 培训学校前台接待礼仪
- 眼外伤课件教学课件
- DB11∕T 695-2025 建筑工程资料管理规程
评论
0/150
提交评论