用二进制补码表示负整数

发布于 2021-01-29 14:11:12

我想使用二进制补码表示一位负整数。使用标准的Python位表示实用程序并没有多大帮助:

>>> bin(-5)
'-0b101'
>>> format(-5, 'b')
'-101'

-5的补码形式为1011。我该怎么做呢?

关注者
0
被浏览
106
1 个回答
  • 面试哥
    面试哥 2021-01-29
    为面试而生,有面试问题,就找面试哥。

    Python的整数已经使用二进制补码,但是由于它们具有任意精度,因此负数的二进制表示形式在开始时将具有一个无限的1s字符串,就像正数具有一个无限的0s字符串一样。由于显然无法显示,因此用负号代替。

    如果您想要特定宽度的二进制表示形式,则可以使用模数。

    >>> bin(-5)
    '-0b101'
    >>> bin(-5 % (1<<32))
    '0b11111111111111111111111111111011'
    


知识点
面圈网VIP题库

面圈网VIP题库全新上线,海量真题题库资源。 90大类考试,超10万份考试真题开放下载啦

去下载看看