用二进制补码表示负整数

问题描述

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

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

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

解决方法

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

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

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