进制间转换关系
- 十进制转十六进制
变成二进制取最低四位(&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("");