问题描述
十六进制数是在程序设计时经常要使用到的一种整数的表示方式。它有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
代码如下:
import java.util.*;
public class Main{
public static void g(String s) {
StringBuffer sb = new StringBuffer("");
for (int i=0; i<s.length(); i+=4) {
String s1 = s.substring(i, i+4);
switch(s1) {
case "0000" : sb.append("0"); break;
case "0001" : sb.append("1"); break;
case "0010" : sb.append("2"); break;
case "0011" : sb.append("3"); break;
case "0100" : sb.append("4"); break;
case "0101" : sb.append("5"); break;
case "0110" : sb.append("6"); break;
case "0111" : sb.append("7"); break;
case "1000" : sb.append("8"); break;
case "1001" : sb.append("9"); break;
case "1010" : sb.append("A"); break;
case "1011" : sb.append("B"); break;
case "1100" : sb.append("C"); break;
case "1101" : sb.append("D"); break;
case "1110" : sb.append("E"); break;
case "1111" : sb.append("F"); break;
}
}
if(sb.charAt(0) == '0') System.out.println(sb.substring(1, sb.length()));
else System.out.println(sb);
}
public static void f(int n) {
StringBuffer sb = new StringBuffer("");
while(n!=0) {
int m = n%2;
sb.insert(0, m);
n = n / 2;
}
if(sb.length()%4==1) sb.insert(0, "000");
if(sb.length()%4==2) sb.insert(0, "00");
if(sb.length()%4==3) sb.insert(0, "0");
g(sb.toString());
}
public static void main(String[] args) {
Scanner in = new Scanner(System.in);
int n = in.nextInt();
if (n==0) System.out.println(0);
else
f(n);
}
}
思路: 先把10进制转化为2进制,再把2进制转化为16进制,要注意的是0这个数有点特殊。