基本算法:十六进制的数转换为二进制的数:每一位十六进制的数码转换为四位二进制数码(移位运算)。因为无论是浮点是还是整数在计算机内部存储的形式:二进制补码的形式。将数编码的第一位右移到最后一位,然后在与上1,通过循环便可以将该数的二进制编码形式输出。
//以下是简单代码的展示
/**
*将十六进制的数转换成二进制的数:十六进制的每一位数码转换成对应的二进制数码(从左往右,碰到小数点照样输出)
*/
import java.util.Scanner;
public class H2B
{
public static void main(String[] args)
{
String base = "0123456789ABCDEF";
Scanner sc = new Scanner(System.in);
System.out.print("请输入十六进制的数:");
String input = sc.next();
System.out.print("十六进制的数:" + input + "转换成二进制数的结果为:");
for(int i = 0; i < input.length(); i++)
{
//接收字符
char ch = input.charAt(i);
if(ch >= 'a' && ch <= 'f')
{
ch = (char)(ch - ('a' - 'A'));//将小写字母大写化
}
if(ch == '.')
{
System.out.print(". ");
}
else
{
int t = base.indexOf(ch); //如果是A--->10
//将该十六位进制的数码转换成四位二进制数:移位(位运算)
for(int j = 3; j >= 0; j--)//8在计算机内部的存储形式:二进制补码(1000)
{ //无符号右移动
System.out.print((t >>> j) & 1);
}
System.out.print(" ");
}
}
System.out.println();
}
}
代码测试结果截图: