用编程实现将十进制数转成二进制时整数部分是很简单的,复杂的是小数部分。
整数部分代码如下:
System.out.println("请输入一个10进制的数:");
Scanner sc = new Scanner(System.in);
double d = sc.nextDouble();
// 整数部分
int z = (int)d;
// 小数部分
double x = d-z;
long j = 1;long sum=0;
// 整数部分转换为二进制
for(int i=z;i>0;i=i/2){
sum+=i%2*j;
j*=10;
至于小数部分计算就复杂的多,小数部分的计算需要每次取小数部分乘以2后的结果的整数部分,在代码中想要实现复杂的多,下面是我写的代码,可以参考一下。
// 小数部分转换为二进制(乘2取整)
double sumx=0.0,k=0.1;
int h = 1;
for(;;k=k/10){
x=(x-(int)x)*2;
sumx+=(int)x*k;
h++;
if(x-(int)x==0.0 || h==15){
break;
}
}
System.out.println(sum+sumx);
把整数部分和小数部分合在一起就是完整的代码。