HDOJ 2031 进制转换

简介: HDOJ 2031 进制转换

Problem Description

输入一个十进制数N,将它转换成R进制数输出。


Input

输入数据包含多个测试实例,每个测试实例包含两个整数N(32位整数)和R(2<=R<=16, R<>10)。


Output

为每个测试实例输出转换后的数,每个输出占一行。如果R大于10,则对应的数字规则参考16进制(比如,10用A表示,等等)。


Sample Input

7 2

23 12

-4 3


Sample Output

111

1B

-11

import java.util.Scanner;
public class Main {
    public static void main(String args[]){
        Scanner sc = new Scanner(System.in);
        char[] numbers = {'0','1','2','3','4','5','6','7','8','9','A','B','C','D','E','F'};
        while(sc.hasNext()){
            int n = sc.nextInt();
            int r = sc.nextInt();
            int m=n;
            if(n<0){
                n=-n;
            }
            String number = "";
            int a=n/r;
            n=n%r;
            number=numbers[n]+number;
            while(a>0){
                n=a%r;
                a=a/r;
                number=numbers[n]+number;
            }
            if(m>0)
            System.out.println(number);
            else{
                System.out.println('-'+number);
            }
        }
    }
}
目录
相关文章
HDOJ 1056 HangOver(水题)
HDOJ 1056 HangOver(水题)
100 0
HDOJ 1056 HangOver(水题)
|
Java 测试技术
HDOJ(HDU) 1877 又一版 A+B(进制、、)
HDOJ(HDU) 1877 又一版 A+B(进制、、)
96 0
HDOJ 1335 Basically Speaking(进制转换)
HDOJ 1335 Basically Speaking(进制转换)
93 0
|
Java
HDOJ(HDU) 1720 A+B Coming(进制)
HDOJ(HDU) 1720 A+B Coming(进制)
115 0
|
索引
HDOJ/HDU 2567 寻梦(字符串简单处理)
HDOJ/HDU 2567 寻梦(字符串简单处理)
105 0
|
测试技术
HDOJ 1108 最小公倍数
HDOJ 1108 最小公倍数
98 0
|
Java
HDOJ 1753 大明A+B(大数~)
HDOJ 1753 大明A+B(大数~)
112 0
HDOJ(HDU) 2106 decimal system(进制相互转换问题)
HDOJ(HDU) 2106 decimal system(进制相互转换问题)
85 0
HDOJ 2012 素数判定
HDOJ 2012 素数判定
121 0
HDOJ 2099 整除的尾数
HDOJ 2099 整除的尾数
85 0