首页 技术 正文
技术 2022年11月11日
0 收藏 888 点赞 2,805 浏览 951 个字

二进制小数 牛客网 程序员面试金典

  • 题目描述

  • 有一个介于0和1之间的实数,类型为double,返回它的二进制表示。如果该数字无法精确地用32位以内的二进制表示,返回“Error”。

  • 给定一个double num,表示0到1的实数,请返回一个string,代表该数的二进制表示或者“Error”。

  • 测试样例:

  • 0.625

  • 返回:0.101

C++

class BinDecimal {
public:
//run:3ms memory:484k
string printBin(double num) {
string str("0.");
double base = 0.5;
for(;num >0; base /=2){
if (num >= base){
num -= base;
str += "1";
}else str += "0";
if(str.size() > 32) return str = "Error";
}
return str;
}
//run:3ms memory:476k
string printBin2(double num) {
string str("0.");
double base = 0.5;
while(num > 0){
if(num >= base){
num -= base;
str += "1";
}
else
str += "0";
base /= 2;
if(str.size() > 32)
return str = "Error";
}
return str;
}
};

Python

class BinDecimal:
def printBin(self, num):
lt = ["0","."]
base = 0.5
while num > 0:
if num >= base:
num -= base;
lt.append("1")
else:
lt.append("0")
base /= 2
if len(lt) >=32: return "Error"
return ''.join(lt) def printBin2(self, num):
if num >= 1 or num <= 0:
return "Error"
binary = ['0', '.']
while num > 0:
if len(binary) >= 32:
return "Error"
r = num * 2
if r >= 1:
binary.append('1')
num = r - 1
else:
binary.append('0')
num = r
return ''.join(binary)
相关推荐
python开发_常用的python模块及安装方法
adodb:我们领导推荐的数据库连接组件bsddb3:BerkeleyDB的连接组件Cheetah-1.0:我比较喜欢这个版本的cheeta…
日期:2022-11-24 点赞:878 阅读:9,501
Educational Codeforces Round 11 C. Hard Process 二分
C. Hard Process题目连接:http://www.codeforces.com/contest/660/problem/CDes…
日期:2022-11-24 点赞:807 阅读:5,915
下载Ubuntn 17.04 内核源代码
zengkefu@server1:/usr/src$ uname -aLinux server1 4.10.0-19-generic #21…
日期:2022-11-24 点赞:569 阅读:6,747
可用Active Desktop Calendar V7.86 注册码序列号
可用Active Desktop Calendar V7.86 注册码序列号Name: www.greendown.cn Code: &nb…
日期:2022-11-24 点赞:733 阅读:6,505
Android调用系统相机、自定义相机、处理大图片
Android调用系统相机和自定义相机实例本博文主要是介绍了android上使用相机进行拍照并显示的两种方式,并且由于涉及到要把拍到的照片显…
日期:2022-11-24 点赞:512 阅读:8,143
Struts的使用
一、Struts2的获取  Struts的官方网站为:http://struts.apache.org/  下载完Struts2的jar包,…
日期:2022-11-24 点赞:671 阅读:5,306