如何解决将Double转换为二进制表示形式?
| 我试图将一个double转换为其二进制表示形式,但是使用此Long.toBinaryString(Double.doubleToRawLongBits(d))
并没有帮助,因为我有很多数字,因此Long不能存储它们,即2^900
。
解决方法
Long.toBinaryString(Double.doubleToRawLongBits(d))
似乎工作正常。
System.out.println(\"0: 0b\" + Long.toBinaryString(Double.doubleToRawLongBits(0D)));
System.out.println(\"1: 0b\" + Long.toBinaryString(Double.doubleToRawLongBits(1D)));
System.out.println(\"2: 0b\" + Long.toBinaryString(Double.doubleToRawLongBits(2D)));
System.out.println(\"2^900: 0b\" + Long.toBinaryString(Double.doubleToRawLongBits(Math.pow(2,900))));
System.out.println(\"Double.MAX_VALUE: 0b\" + Long.toBinaryString(Double.doubleToRawLongBits(Double.MAX_VALUE)));
/*
prints:
0: 0b0
1: 0b11111111110000000000000000000000000000000000000000000000000000
2: 0b100000000000000000000000000000000000000000000000000000000000000
2^900: 0b111100000110000000000000000000000000000000000000000000000000000
Double.MAX_VALUE: 0b111111111101111111111111111111111111111111111111111111111111111
*/
, 您可能要处理整个和小数部分:
public String toBinary(double d,int precision) {
long wholePart = (long) d;
return wholeToBinary(wholePart) + \'.\' + fractionalToBinary(d - wholePart,precision);
}
private String wholeToBinary(long l) {
return Long.toBinaryString(l);
}
private String fractionalToBinary(double num,int precision) {
StringBuilder binary = new StringBuilder();
while (num > 0 && binary.length() < precision) {
double r = num * 2;
if (r >= 1) {
binary.append(1);
num = r - 1;
} else {
binary.append(0);
num = r;
}
}
return binary.toString();
}
, 您可以使用BigInteger来保存您的大数,并使用BigInteger.toString()方法来检索它的二进制表示形式。
BigInteger bigNum = new BigInteger(sYourNum);
System.out.println( bigNum.toString(2) );
, 您是否尝试过使用java.math.BigInteger
并使用参数2调用toString(int radix)
?
, 您可以使用Double.toHexString(d),然后使用for循环和StringBuilder将十六进制字符串转换为二进制字符串。
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。