進制間轉換關係
- 十進制轉十六進制
變成二進制取最低四位(&15也就是4位都是1)算值,然後再右移4位,再&15得到值,最後將值反過來就是對應的十六進制。
使用查表法十進制轉十六進制
0 1 2 3 4 5 6 7 8 9 A B C D E F 十六進制元素
0 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 相當於數組的角標
先&15,再右移4位。若值還不爲0則繼續右移4位,再&15 - 十進制轉八進制
先&7(取最低3位),再右移3位。若值還不爲0則繼續右移3位,再&7 - 十進制轉二進制
先&1(取最低1位),再右移1位。若值還不爲0則繼續右移1位,再&1
public static void trans(int num,int base,int offset) {
if(num==0) {//當是數字0進行進制轉換則直接打印0並返回
System.out.println(0);
return ;
}
//定義一個容器
char[] chs = {'0','1','2','3'
,'4','5','6','7'
,'8','9','A','B'
,'C','D','E','F'};
//
char[] arr =new char[32];
int pos = arr.length;//定義一個類似於指針的變量,是arr的長度
while(num!=0) {//當要轉換的數字不爲0
int temp=num & base;//先&上base(15/7/1)
//arr先取長度,然後減1得到對應的下標,從最後一個位開始存對應存儲進去
arr[--pos] = chs[temp];//再將&base之後的結果通過表結構chs[下標](下標小於10,則一樣,反之則對應字母)
num = num >>> offset; //緊接着右移offset(4/3/1)
}
for(int x=pos;x<arr.length;x++) {//循環遍歷正打印存儲的值
System.out.print(arr[x]);
}
}
arr[–pos] = chs[temp];剛開始時pos指向的位置是空白地方,先自減1之後,
指向了對應的數組下標的位置。存儲第一次&base得到的值
右移offset位之後再&base,得到的值再存對應位置(對應位置也自減1)。
調用
//十進制-》二進制
System.out.println("6十進制-》二進制");
trans(6,1,1);
System.out.println("");
//十進制-》八進制
System.out.println("60十進制-》八進制");
trans(60,7,3);
System.out.println("");
//十進制-》十六進制
System.out.println("60十進制-》十六進制");
trans(60,15,4);
System.out.println("");