HDOJ(HDU) 2097 Sky数(进制)

简介: Problem Description Sky从小喜欢奇特的东西,而且天生对数字特别敏感,一次偶然的机会,他发现了一个有趣的四位数2992,这个数,它的十进制数表示,其四位数字之和为2+9+9+2=22,它的十六进制数BB0,其四位数字之和也为22,同时它的十二进制数表示1894,其四位数字之和也为22,啊哈,真是巧啊。

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.

用java的Integer类中的toString方法,很容易将一个10进制的数转换为其他进制的数。
慢慢的体验Java方法的强大吧。。。

import java.util.Scanner;

public class Main{

    public static void main(String[] args) {
        Scanner sc = new Scanner(System.in);
        char hex[] = {'a','b','c','d','e','f'};
        while(sc.hasNext()){
            int n10 = sc.nextInt();
            if(n10==0){
                return;
            }
            int a=0;
            int b=0;
            int c=0;
            String strn16 = Integer.toString(n10, 16);
            String strn12 = Integer.toString(n10, 12);
            int k=n10;
            while(k!=0){
                a=a+k%10;
                k=k/10;
            }
            //System.out.println(a);
            boolean isNum = true;
            for(int i=0;i<strn16.length();i++){
                isNum = true;
                for(int j=0;j<hex.length;j++){
                    if(strn16.charAt(i)==hex[j]){
                        b+=10+j;
                        isNum=false;
                        break;
                    }
                }
                if(isNum){
                    b+=Integer.parseInt(""+strn16.charAt(i));
                }
            }
            if(a!=b){
                System.out.println(n10+" is not a Sky Number.");
                continue;
            }
            for(int i=0;i<strn12.length();i++){
                isNum = true;
                for(int j=0;j<hex.length;j++){
                    if(strn12.charAt(i)==hex[j]){
                        c+=10+j;
                        isNum=false;
                        break;
                    }
                }
                if(isNum){
                    c+=Integer.parseInt(""+strn12.charAt(i));
                }
            }
            if(a!=c){
                System.out.println(n10+" is not a Sky Number.");
                continue;
            }
            System.out.println(n10+" is a Sky Number.");
        }
    }
}
目录
相关文章
|
7月前
|
测试技术
华为机试HJ5:进制转换
华为机试HJ5:进制转换
|
数据安全/隐私保护
HDU-2100,Lovekey(大数加法,26进制)
HDU-2100,Lovekey(大数加法,26进制)
|
Java
HDOJ(HDU) 2097 Sky数(进制)
HDOJ(HDU) 2097 Sky数(进制)
82 0
|
Java 测试技术
HDOJ(HDU) 1877 又一版 A+B(进制、、)
HDOJ(HDU) 1877 又一版 A+B(进制、、)
77 0
HDOJ/HDU 2352 Verdis Quo(罗马数字与10进制数的转换)
HDOJ/HDU 2352 Verdis Quo(罗马数字与10进制数的转换)
152 0
|
测试技术
HDOJ(HDU) 1860 统计字符
HDOJ(HDU) 1860 统计字符
80 0
HDOJ(HDU) 2107 Founding of HDU(找最大值)
HDOJ(HDU) 2107 Founding of HDU(找最大值)
73 0
HDOJ/HDU 2561 第二小整数(水题~排序~)
HDOJ/HDU 2561 第二小整数(水题~排序~)
92 0
HDOJ/HDU 1984 Mispelling4(删除第n个字符~)
HDOJ/HDU 1984 Mispelling4(删除第n个字符~)
82 0