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());
}
}
}
蓝桥杯:进制转换(java)
猜你喜欢
转载自blog.csdn.net/microopithecus/article/details/85000730
今日推荐
周排行