码迷,mamicode.com
首页 > 其他好文 > 详细

1019 数字黑洞 (20分)/1069 The Black Hole of Numbers (20分)

时间:2020-07-18 11:39:12      阅读:78      评论:0      收藏:0      [点我收藏+]

标签:||   printf   写法   转换   algorithm   class   ==   array   turn   

 

#include<iostream>
#include<algorithm>
#include<cstdio>

using namespace std;

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

void to_array(int n,int num [])
{
    for(int i=0;i<4;i++)
    {
        num[i]=n%10;
        n/=10;
    }
    
} 

int  to_number(int num[])//void to_number(int num[],int n)这样写就错了; 
{
    int sum=0;
    
    for(int i=0;i<4;i++){
    sum=sum*10+num[i];//注意sum*10 这才是 x10 累加 的正确写法 
        
    }
    return sum;//记得返回总值; 
}

int main ()
{
    int a,maxn,minn;
    cin>>a;
    int num[5];
    
    while(1){
        to_array(a,num); //是num  不是num[5]!!!
        sort(num,num+4);
        minn=to_number(num);
        sort(num,num+4,cmp);
        maxn=to_number(num);
        a=maxn-minn;
//        cout<<maxn<<"-"<<minn<<"="<<a<<endl;
//         这种写法不能输出如7850 转换的  0587 ,会错误输出587

        printf("%04d - %04d = %04d\n",maxn,minn,a);// 别忘了换行符 
//        这里有个比较狗的格式错误“"%04d-%04d=%04d"” (已改) 
        if(a==0||a==6174)
        break;
    }
    return 0;
}

 

1019 数字黑洞 (20分)/1069 The Black Hole of Numbers (20分)

标签:||   printf   写法   转换   algorithm   class   ==   array   turn   

原文地址:https://www.cnblogs.com/leamant/p/13334481.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!