HDOJ 2031 进制转换

简介: Problem Description 输入一个十进制数N,将它转换成R进制数输出。Input 输入数据包含多个测试实例,每个测试实例包含两个整数N(32位整数)和R(2

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(水题)
96 0
HDOJ 1056 HangOver(水题)
HDOJ 2031 进制转换
HDOJ 2031 进制转换
93 0
|
Java 测试技术
HDOJ(HDU) 1877 又一版 A+B(进制、、)
HDOJ(HDU) 1877 又一版 A+B(进制、、)
93 0
HDOJ 1335 Basically Speaking(进制转换)
HDOJ 1335 Basically Speaking(进制转换)
91 0
|
Java
HDOJ(HDU) 1720 A+B Coming(进制)
HDOJ(HDU) 1720 A+B Coming(进制)
110 0
HDOJ 2099 整除的尾数
HDOJ 2099 整除的尾数
83 0
|
索引
HDOJ/HDU 2567 寻梦(字符串简单处理)
HDOJ/HDU 2567 寻梦(字符串简单处理)
95 0
HDOJ(HDU) 2106 decimal system(进制相互转换问题)
HDOJ(HDU) 2106 decimal system(进制相互转换问题)
83 0
HDOJ 2032 杨辉三角
HDOJ 2032 杨辉三角
109 0
|
Java
HDOJ(HDU) 2502 月之数(进制)
HDOJ(HDU) 2502 月之数(进制)
104 0