本文代码可在我的github中BinDecimal.java中找到。
题目描述:
有一个介于0和1之间的实数,类型为double,返回它的二进制表示。如果该数字无法精确地用32位以内的二进制表示,返回“Error”。 给定一个double num,表示0到1的实数,请返回一个string,代表该数的二进制表示或者“Error”。
思路分析:
一位一位的判断,判断一位去掉一位。并且另起一个字符串进行表示。
代码:
package newcoder; public class BinDecimal { public String printBin(double num) { String res = "0."; double base = 0.5; while (num > 0)//继续判断的条件就是num依然存在 { if (num >= base)//判断某位是用1还是用0表示 { res += "1"; num -= base; } else res += "0"; base /= 2;//移动一位 if (res.length() > 34)//“0.”占2个字符位置。 { res = "Error"; break; } } return res; } }