问题描述
十六进制数是在程序设计时经常要使用到的一种整数的表示方式。它有0,1,2,3,4,5,6,7,8,9,A,B,C,D,E,F共16个符号,分别表示十进制数的0至15。十六进制的计数方法是满16进1,所以十进制数16在十六进制中是10,而十进制的17在十六进制中是11,以此类推,十进制的30在十六进制中是1E。
给出一个非负整数,将它表示成十六进制的形式。
输入格式
输入包含一个非负整数a,表示要转换的数。0<=a<=2147483647
输出格式
输出这个整数的16进制表示
样例输入
30
样例输出
1E
递归的方法,依次处理最后一位。用StringBuffer,比StringBuilder线程安全,要迅速不要安全的话也可以使用StringBuilder。insert把得到的放在首
代码:
import java.util.Scanner;
public class Test {
public static void main(String[] args) {
Scanner scanner = new Scanner(System.in);
int n = scanner.nextInt();
change(n);
}
public static void change(int n) {
StringBuffer s = new StringBuffer();
if (n == 0) {
System.out.println(0);
return;
}
int m;
while (n > 0) {
m = n % 16;
n = n / 16;
switch (m) {
case 0:
s.insert(0, "0");
break;
case 1:
s.insert(0, "1");
break;
case 2:
s.insert(0, "2");
break;
case 3:
s.insert(0, "3");
break;
case 4:
s.insert(0, "4");
break;
case 5:
s.insert(0, "5");
break;
case 6:
s.insert(0, "6");
break;
case 7:
s.insert(0, "7");
break;
case 8:
s.insert(0, "8");
break;
case 9:
s.insert(0, "9");
break;
case 10:
s.insert(0, "A");
break;
case 11:
s.insert(0, "B");
break;
case 12:
s.insert(0, "C");
break;
case 13:
s.insert(0, "D");
break;
case 14:
s.insert(0, "E");
break;
case 15:
s.insert(0, "F");
break;
}
}
System.out.println(s);
}
}