蓝桥杯:进制转换(java)

package lanqiaobei;

import java.util.HashMap;
import java.util.Scanner;
import java.util.Stack;

/*
练习题:进制转换
输入一个十进制数 N,将它转换成 R 进制数输出。在 10≤R≤16的情况下,用'A'表示 10,用'B'表示 11,
用'C'表示 12,用'D'表示 13,用'E'表示 14,用'F'表示 15。
输入格式
输入包含两个整数 N(N≤10000) 和 R(2≤R≤16)。
注意,N 有可能是负整数。
输出格式
输出一行,表示转换后的数。
样例输入
23 12
样例输出
1B
 */
public class Njinzhishu {
    public static void main(String[] args) {
        Scanner sc=new Scanner(System.in);
        int n=sc.nextInt();
        int r=sc.nextInt();
        Stack<Character> s=new Stack<>();
        HashMap<Integer,Character> juge=new HashMap<>();
        juge.put(10,'A');
        juge.put(11,'B');
        juge.put(12,'C');
        juge.put(13,'D');
        juge.put(14,'E');
        juge.put(15,'F');
        while (n>0){
            int re=n%r;
            n/=r;
            if (re>=10){
                s.push(juge.get(re));
            }else {
                s.push((char)(re+48));
            }
        }
        /*if (n>=10){
            s.push(juge.get(n));
        }else {
            s.push((char)(n+48));
        }
*/
        while (!s.isEmpty()){
            System.out.print(s.pop());
        }
    }

}

猜你喜欢

转载自blog.csdn.net/microopithecus/article/details/85000730