• 杭电 2097 sky数


    Sky数

    Time Limit: 1000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)
    Total Submission(s): 24146    Accepted Submission(s): 13701


    Problem Description
    Sky从小喜欢奇特的东西,而且天生对数字特别敏感,一次偶然的机会,他发现了一个有趣的四位数2992,这个数,它的十进制数表示,其四位数字之和为2+9+9+2=22,它的十六进制数BB0,其四位数字之和也为22,同时它的十二进制数表示1894,其四位数字之和也为22,啊哈,真是巧啊。Sky非常喜欢这种四位数,由于他的发现,所以这里我们命名其为Sky数。但是要判断这样的数还是有点麻烦啊,那么现在请你帮忙来判断任何一个十进制的四位数,是不是Sky数吧。
     
    Input
    输入含有一些四位正整数,如果为0,则输入结束。
     
    Output
    若n为Sky数,则输出“#n is a Sky Number.”,否则输出“#n is not a Sky Number.”。每个结果占一行。注意:#n表示所读入的n值。
     
    Sample Input
    2992 1234 0
     
    Sample Output
    2992 is a Sky Number. 1234 is not a Sky Number.
     
    就是简单的搞成12进制数,判断下各位只和即可,这题还是比较方便的,不需要用到那中ABCD的输出,我直接用数组存一下就可以了,最后把他们全部加起来,判断下就行了。
    AC代码如下:
    #include <iostream>
    #include<math.h>
    #include <iomanip>
    #include<cstdio>
    #include<string>
    #include<map>
    #include<vector>
    #include<list>
    #include<algorithm>
    #include<stdlib.h>
    #include<iterator>
    #include<sstream>
    #include<string.h>
    using namespace std;
    
    
    int main()
    {
        int n;
        while(cin>>n)
        {
            if(n==0)
            {
                break;
            }
            int a1[4];
            int a2[4];
            int a3[4];
            memset(a1,0,4*sizeof(int));
            memset(a2,0,4*sizeof(int));
            memset(a3,0,4*sizeof(int));
    
            int temp10=n;
            int i=3;
            while(temp10>0)
            {
                a1[i]=temp10%10;
                temp10=temp10/10;
                i--;
            }
    
            int temp12=n;
            i=3;
            while(temp12>0)
            {
                a2[i]=temp12%12;
                temp12=temp12/12;
                i--;
            }
    
            int temp16=n;
            i=3;
            while(temp16>0)
            {
                a3[i]=temp16%16;
                temp16=temp16/16;
                i--;
            }
    
            int cnt10=0;
            int cnt12=0;
            int cnt16=0;
    
            for(int j=0;j<4;j++)
            {
                cnt10=a1[j]+cnt10;
                cnt12=a2[j]+cnt12;
                cnt16=a3[j]+cnt16;
            }
    /*
            cout<<cnt10<<endl;
            cout<<cnt12<<endl;
            cout<<cnt16<<endl;
    */
        if(cnt10==cnt12&&cnt10==cnt16&&cnt12==cnt16)
        {
            cout<<n<<" is a Sky Number."<<endl;
        }
        else
        {
            cout<<n<<" is not a Sky Number."<<endl;
        }
    
    
        }
        return 0;
    }
  • 相关阅读:
    FastReport.Net使用:[13]如何使用表达式
    FastReport.Net使用:[11]公共对象属性介绍
    FastReport.Net使用:[10]报表栏目说明
    FastReport.Net使用:[9]多栏报表(多列报表)
    FastReport.Net使用:[8]交叉表一
    FastReport.Net使用:[7]打印空白行
    FastReport.Net使用:[6]HTML标签使用
    测试,测试开发,QA,QM,QC--------- 测试之路勿跑偏
    java 接口自动化测试之数据请求的简单封装
    java HttpClient POST请求
  • 原文地址:https://www.cnblogs.com/William-xh/p/6986295.html
Copyright © 2020-2023  润新知