十进制转化为二进制,八进制,十六进制
程序员文章站
2022-07-15 08:38:25
...
十进制转化为二进制,八进制,十六进制,不管输入的是正数还是负数,都行。
其代码如下:
public class Demo15 {
public static void main(String[] args){
toBin(80); //十进制-->二进制
System.out.println();
toBin(-80); //十进制-->二进制
System.out.println();
toBa(80); //十进制-->八进制
System.out.println();
toBa(-80); //十进制-->八进制
System.out.println();
toHex(80); //十进制-->十六进制
System.out.println();
toHex(-80); //十进制-->十六进制
}
/*
* 十进制-->二进制
*/
public static void toBin(int num){
trans(num,1,1);
}
/*
* 十进制-->八进制
*/
public static void toBa(int num){
trans(num,7,3);
}
/*
* 十进制-->十六进制
*/
public static void toHex(int num){
trans(num, 15, 4);
}
public static void trans(int num,int base,int offset){
//num指的是要传进的十进制数,base是指如果是二进制,base=1,八进制:base=7,十六进制:base=15;
//offset是指要右移的位数,如果是二进制,offset=1,八进制:offset=3,十六进制:offset=4
if(num==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;
while(num!=0){
int temp=num & base;
arr[--pos]=chs[temp];
num=num>>>offset;
}
for(int x=pos;x<arr.length;x++){
System.out.print(arr[x]);
}
}
}
输出结果为:
1010000
11111111111111111111111110110000
120
37777777660
50
FFFFFFB0
上一篇: 编译Linux内核 4.13
下一篇: 算法:求一元二次方程的根