给定任一个各位数字不完全相同的 4 位正整数,如果我们先把 4 个数字按非递增排序,再按非递减排序,然后用第 1 个数字减第 2 个数字,将得到一个新的数字。一直重复这样做,我们很快会停在有“数字黑洞”之称的 6174,这个神奇的数字也叫 Kaprekar 常数。

例如,我们从6767开始,将得到

7766 - 6677 = 1089
9810 - 0189 = 9621
9621 - 1269 = 8352
8532 - 2358 = 6174
7641 - 1467 = 6174
... ...

现给定任意 4 位正整数,请编写程序演示到达黑洞的过程。

输入格式:

输入给出一个 ( 区间内的正整数 N。

输出格式:

如果 N 的 4 位数字全相等,则在一行内输出 N - N = 0000;否则将计算的每一步在一行内输出,直到 6174 作为差出现,输出格式见样例。注意每个数字按 4 位数格式输出。

输入样例 1:

6767

输出样例 1:

7766 - 6677 = 1089
9810 - 0189 = 9621
9621 - 1269 = 8352
8532 - 2358 = 6174

输入样例 2:

2222

输出样例 2:

2222 - 2222 = 0000
#include <iostream>
using namespace std;
int sortInt(int a){
int hash[]={};
while(a!=){
hash[a%]++;
a/=;
}
for(int i=;i>=;i--){
while(hash[i]!=){
a=a*+i;
hash[i]--;
}
}
int plus;
if(a>=) plus=;
else if(a<&&a>=) plus=;
else if(a<&&a>=) plus=;
else plus=;
return a*plus;
}
int reverse(int a){
int plus;
if(a>=) plus=;
else if(a<&&a>=) plus=;
else if(a<&&a>=) plus=;
else plus=;
int ans=;
while(a!=){
ans=ans*+a%;
a/=;
}
return ans*plus;
}
int main()
{
int a,b;
cin>>a;
if(a==) printf("7641 - 1467 = 6174\n");
while(a!=&&a!=){
a=sortInt(a);
b=reverse(a);
printf("%04d - %04d = %04d\n",a,b,(a-b));
a=a-b;
}
system("pause");
return ;
}

最新文章

  1. Markdown Blog Testing
  2. ubuntu samba server 配置多用户访问
  3. C#------EntityFramework实体加载数据库SQLServer(MySQL)
  4. Mac 下查看 Android Studio 的 SHA1的方法
  5. 用re-sign.jar重签名apk后安装失败的解决办法
  6. C/C++走过的坑(基础问题篇)
  7. 技术揭秘12306改造(一):尖峰日PV值297亿下可每秒出票1032张
  8. 思考之spring的ioc
  9. 对于Android Service 生命周期进行全解析
  10. mvc与My97DatePicker插件的结合
  11. 第一个WebAPI项目
  12. (NO.00003)iOS游戏简单的机器人投射游戏成形记(七)
  13. selenium中下拉框的定位
  14. git教程:版本退回
  15. AngularJS 1.x 思维索引
  16. 初识异步、并发处理纯代码及Demo
  17. VS2017 启动调试出现 无法启动程序“http://localhost:15613” 操作在当前状态中是非法的。 同时附加进程也是错误的解决方法
  18. ZKWeb网页框架1.8正式发布
  19. saxon 处理xslt
  20. HTML5之拖拽

热门文章

  1. Nginx 代理TCP/UDP 端口
  2. Rxjava2实战--第四章 Rxjava的线程操作
  3. FICO相关号码范围IMG设定
  4. configmap使用-查看configmap个数
  5. C基础知识(14):命令行参数
  6. 行为验证码的asp.net MVC实现方式 qq521877626
  7. python开发工具-pycharm专业版
  8. git(程序员的时光机)
  9. Django 数据库操作
  10. classmethod自己定制