PAT (Advanced Level) Practice 1069 The Black Hole of Numbers

#include <iostream>
#include<stdio.h>
#include<algorithm>
using namespace std;

bool cmp(int a,int b) //降序
{
    return a > b;
}

int getNumber(int a[],int len) //从数组取出数字
{
    int sum = 0;
    for(int i=len-1;i>=0;i--)
    {
            sum = sum*10 + a[i];
    }
    return sum;
}

void saveArray(int a[],int len,int n){ //数字存入数组
    for(int i=0;i<len;i++)
        a[i] = 0;

    len--;
    while(len >=0 && n!=0){
        a[len--] = n % 10;
        n = n / 10;
    }
}

int main()
{
    int a[4] = {0};
    int number;
    scanf("%d",&number);
    int i=3;
    do{
        a[i--] = number % 10;
        number = number / 10;
    }while(number != 0 && i>=0);

    int in_number;
    int de_number;
    int result;
    do{
        sort(a,a+4); //升序
        in_number = getNumber(a,4);
        sort(a,a+4,cmp);//降序
        de_number = getNumber(a,4);
        result = in_number - de_number;
        printf("%04d - %04d = %04d\n",in_number,de_number,result);
        saveArray(a,4,result);
    }while(result != 0 && result != 6174);
    return 0;
}

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值