Skip to content

Latest commit

 

History

History
61 lines (40 loc) · 1.16 KB

二进制数转字符串.md

File metadata and controls

61 lines (40 loc) · 1.16 KB

面试题 05.02. 二进制数转字符串

https://leetcode-cn.com/problems/bianry-number-to-string-lcci/

题目描述

二进制数转字符串。给定一个介于0和1之间的实数(如0.72),类型为double,打印它的二进制表达式。如果该数字无法精确地用32位以内的二进制表示,则打印“ERROR”。

示例1:

 输入:0.625
 输出:"0.101"
示例2:

 输入:0.1
 输出:"ERROR"
 提示:0.1无法被二进制准确表示
提示:

32位包括输出中的"0."这两位。

来源:力扣(LeetCode)
链接:https://leetcode-cn.com/problems/bianry-number-to-string-lcci
著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。

思路

每次cheng乘2,然后取个位数

python代码

class Solution:
    def printBin(self, num: float) -> str:
        res="0."
        count=0
        while(num!=0):
            count+=1
            if(count>32):
                return 'ERROR'
            num*=2
            if(num>=1):
                res+='1'
                num-=1
            else:
                res+='0'
        return res