zoukankan      html  css  js  c++  java
  • 1019. 数字黑洞 (20)

     

    时间限制 1000 ms 内存限制 32768 KB 代码长度限制 100 KB 判断程序 Standard (来自 小小)

    题目描述

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

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

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

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

     

    /*
      注意:当n等于0时候,出现死循环,这个时候需要排除这种可能存在的情况。
    */
    #include<cstdio> #include<algorithm> #include<iostream> using namespace std; int cmp(int a,int b){ return a > b; } int main(void){ int a[4],n; cin >> n; for(int i=0;i<4;i++){ a[i] = n%10; n/=10; } sort(a,a+4,cmp); int data1,data2,result; do{ data1 = a[0]*1000 + a[1]*100 + a[2]*10 + a[3]; data2 = a[3]*1000 + a[2]*100 + a[1]*10 + a[0]; result = data1 - data2; printf("%04d - %04d = %04d",data1,data2,result); if(result != 6174){ printf(" "); a[0] = result/1000; a[1] = result%1000/100; a[2] = result%100/10; a[3] = result%10; sort(a,a+4,cmp); } }while(result != 6174 && result != 0); return 0; }
  • 相关阅读:
    caffe学习笔记(1)安装
    windows下遍历文件夹
    图像处理之OpenCV
    OpenCV的安装和使用
    使用cpplint检测代码规范
    图像处理之原理
    Python 在cmd中import模块成功,但是在jupyter notebook中No module xxx found
    Win10上使用VS2015编译Caffe2
    Win10, VS2017环境下OpenCV3.4.2的配置
    C++ main函数的参数
  • 原文地址:https://www.cnblogs.com/zuimeiyujianni/p/8507397.html
Copyright © 2011-2022 走看看