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 3555 BOMB(数位dp)
hdoj 3555 BOMB(数位dp)
45 0
每日一题1055:进制转换
题目描述: 编程,输入一个10进制正整数,然后输出它所对应的八进制数。 样例输入:
117 0
|
Java 测试技术
HDOJ(HDU) 1877 又一版 A+B(进制、、)
HDOJ(HDU) 1877 又一版 A+B(进制、、)
102 0
|
存储 Java
HDOJ/HDU 2549 壮志难酬(取小数点后几位~)
HDOJ/HDU 2549 壮志难酬(取小数点后几位~)
118 0
HDOJ 2032 杨辉三角
HDOJ 2032 杨辉三角
119 0
|
索引
HDOJ/HDU 2567 寻梦(字符串简单处理)
HDOJ/HDU 2567 寻梦(字符串简单处理)
122 0
|
Java
HDOJ(HDU) 2502 月之数(进制)
HDOJ(HDU) 2502 月之数(进制)
117 0
|
测试技术
HDOJ 1108 最小公倍数
HDOJ 1108 最小公倍数
106 0
HDOJ 1335 Basically Speaking(进制转换)
HDOJ 1335 Basically Speaking(进制转换)
101 0