十进制数转二进制数,跟据不同的开发语言其转换方式有很多,在Java中如果相把一个十进制的整数来转换成二进制那是举手之劳,非常简单,只要用Integer.toBinaryString(int)方法就可以得到结果。但如果转换的不是一个整数,而是一个带小数部分的十进制数,那就没有那么容易了。由于整数和小数的转换方式不同,所以先将十进制数的整数部分和小数部分分别转换后,再合并转换后的结果即得到想要的结果。
十进制数转二进制数的算法如下:
1. 十进制整数转换为二进制整数
十进制整数转换为二进制整数采用"除2取余,逆序排列"法。具体做法是:用2去除十进制整数,可以得到一个商和余数;再用2去除商,又会得到一个商和余数,如此进行,直到商为零时为止,然后把先得到的余数作为二进制数的低位有效位,后得到的余数作为二进制数的高位有效位,依次排列起来。
2.十进制小数转换为二进制小数
十进制小数转换成二进制小数采用"乘2取整,顺序排列"法。具体做法是:用2乘十进制小数,可以得到积,将积的整数部分取出,再用2乘余下的小数部分,又得到一个积,再将积的整数部分取出,如此进行,直到积中的小数部分为零,或者达到所要求的精度为止。然后把取出的整数部分按顺序排列起来,先取的整数作为二进制小数的高位有效位,后取的整数作为低位有效位。
下面就给出根据十进制数转二进制数的算法所写的一段Java程序以供大家参考:
1. import
2.
3. public class
4.
5. public static void
6. new
7. double d = 8;
8. String s = t.decimal2BinaryStr(d);
9. "十进制数"+d+"转成二进制数为:"+s);
10. }
11.
12. /**
13. * 十进制数转二进制数
14. * @param d 十进制数
15. * @return 十进制数转换成二进制的字符串
16. */
17. public String decimal2BinaryStr(double
18. String result = decimal2BinaryStr_Inte(d);
19. result += decimal2BinaryStr_Deci(d);
20. return
21. }
22.
23. /**
24. * 十进制整数部分转二进制数
25. * @param d 十进制数
26. * @return 十进制整数部分转换成二进制的字符串
27. */
28. public String decimal2BinaryStr_Inte(double
29. // return Integer.toBinaryString((int)d);
30. /*
31. * 本来利用上面的Integer.toBinaryString(int)就可以得到整数部分的二进制结果,
32. * 但为了展示十进制转二进制的算法,现选择以下程序来进行转换
33. */
34. "";
35. long inte = (long)d;
36. int index = 0;
37. while(true){
38. 2;
39. 2;
40. index++;
41. if(index%4 == 0){
42. " ";
43. }
44. if(inte==0){
45. while(index%4!=0){
46. "0";
47. index++;
48. }
49. break;
50. }
51. }
52. char[] c = result.toCharArray();
53. char[] cc = new char[c.length];
54. for(int i=c.length; i>0; i--){
55. 1];
56. }
57. return new
58. }
59.
60. /**
61. * 十进制小数部分转二进制
62. * @param d 十进制数
63. * @return 十进制小数部分转换成二进制小数的字符串
64. */
65. public String decimal2BinaryStr_Deci(double
66. return decimal2BinaryStr_Deci(d, 0);
67. }
68.
69. /**
70. * 十进制小数部分转二进制
71. * @param d 十进制数
72. * @param scale 小数部分精确的位数
73. * @return 十进制小数部分转换成二进制小数的字符串
74. */
75. public String decimal2BinaryStr_Deci(double d, int
76. double deci = sub(d,(long)d);
77. if(deci==0){
78. return "";
79. }
80. //为了防止程序因所转换的数据转换后的结果是一个无限循环的二进制小数,因此给其一个默认的精确度
81. if(scale==0){
82. 2)*4;
83. }
84. int index = 0;
85. new
86. double tempD = 0.d;
87. while(true){
88. if(deci==0
89. while(index%4!=0){
90. "0");
91. index++;
92. }
93. break;
94. }
95. if(index==0){
96. ".");
97. }
98. 2;
99. int)tempD);
100. int)tempD);
101. index++;
102. if(index%4 == 0){
103. " ");
104. }
105. }
106. return
107. }
108.
109.
110. /**
111. * 提供精确的减法运算。
112. * @param v1 被减数
113. * @param v2 减数
114. * @return 两个参数的差
115. */
116. public static double sub(double v1, double
117. new
118. new
119. return
120. }
121. }
例如将十进制数1234.5转成二进制数为:0100 1101 0010.1000