1 public class Test {
2
3 public static void main(String[] args) {
4 System.out.println(toBinary(9));
5 System.out.println(toHex(559));
6 System.out.println(Integer.toBinaryString(9));
7 System.out.println(Integer.toHexString(559));
8 /*1001
9 22F
10 1001
11 22f*/
12 }
13
14 public static String toBinary(int n){
15 StringBuilder temp = new StringBuilder();
16 while(n/2 >=1 || n%2 == 1){//除2取余, (|| n%2 == 1) 在次为了补上最后一个0或者1
17 temp.append(n%2);
18 n = n/2;
19 }
20 return temp.reverse().toString();
21 }
22 /**
23 10进制转16进制:
24 将给定的十进制整数除以基数16,余数便是等值的16进制的最低位。
25 将上一步的商再除以基数16,余数便是等值的16进制数的次低位。
26 重复上一步骤,直到最后所得的商等于0为止。各次除得的余数,便是16进制各位的数,最后一次的余数是最高位
27 */
28 public static String toHex(int n){
29 /*思路:除16取余*/
30 StringBuilder temp = new StringBuilder();
31 while(n/16 >= 1){
32 int aa = n/16;
33 int bb = n%16;
34 //0123456789 10 11 12 13 14 15
35 //0123456789 A B C D E F
36 String str = "";
37 if(bb == 10){
38 str = "A";
39 }else if(bb == 11){
40 str = "B";
41 }else if(bb == 12){
42 str = "C";
43 }else if(bb == 13){
44 str = "D";
45 }else if(bb == 14){
46 str = "E";
47 }else if(bb == 15){
48 str = "F";
49 }else{
50 str = bb+"";
51 }
52 temp.append(str);
53 n = aa;
54 if(n/16 < 1){//补上最后一位
55 temp.append(n);
56 }
57 }
58 return temp.reverse().toString();
59 }
60 }