我的思路是先把2进制数转换成10进制,然后分别转换成8和16进制。
package com.itheima.first;
import java.util.Scanner;
public class zuoye01{
public static void main(String[] args){
Scanner sc=new Scanner(System.in);
System.out.print("输入要转换的二进制数:");
String n=sc.next();
int[] numble=new int[100];
int result10=0,i,result,k,l;//result10储存十进制的结果,k存余数
char[] result8=new char[100];
char[] result16=new char[100];
for(i=0;i<n.length();i++)numble[i]=n.charAt(i)-'0';
for(i=1;(i-1)<n.length();i++){
result10=result10+numble[n.length()-i]*(int)Math.pow(2,i-1);
}
System.out.print("把2进制数"+n+"转化成10进制后为:");
System.out.println(result10);//这里输出10进制结果
result=result10;i=0;//i为储存余数的下标
while(result>0){
k=result%8;
result/=8;
result8[i++]=(char)(k+'0');
}
System.out.print("把2进制数"+n+"转化成8进制后为:");
for(l=0;l<i;l++)System.out.print(result8[i-1-l]);//这里是输出8进制结果
System.out.print('\n');
result=result10;
i=0;
char[] kkk={'0','1','2','3','4','5','6','7','8','9','a','b','c','d','e','f'};
while(result>0){
k=result%16;
result/=16;
result16[i++]=kkk[k];
}
System.out.print("把2进制数"+n+"转化成16进制后为:");
for(l=0;l<i;l++)System.out.print(result16[i-1-l]);
sc.close();
}
}
//2147483647