我正在编写的代码将包含所有 16 位长的负数和正数,MSB 是符号,也就是二进制补码。这意味着我可以拥有的最小数字是 -32768,它是二进制补码形式的 1000 0000 0000 0000
。我可以拥有的最大数字是 32767,即 0111 1111 1111 1111
。
我遇到的问题是 python 使用与正数相同的二进制符号表示负数,只是在前面放一个减号,即 -16384 显示为 -0100 0000 0000 0000
我想为 -16384 这样的数字显示的是 1100 0000 0000 0000
。
我不太确定如何编码。这是我的代码。本质上,如果数字在 180 到 359 之间,则它会是负数。我需要将其显示为二进制恭维值。我没有关于如何显示它的任何代码,因为我真的不知道该怎么做。
def calculatebearingActive(i):
numTracks = trackQty_Active
bearing = (((i)*360.0)/numTracks)
if 0< bearing <=179:
FC = (bearing/360.0)
FC_scaled = FC/(2**(-16))
return int(FC_scaled)
elif 180<= bearing <=359:
FC = -1*(360-bearing)/(360.0)
FC_scaled = FC/(2**(-16))
return int(FC_scaled)
elif bearing ==360:
FC = 0
return FC
最佳答案
如果你正在做类似的事情
format(num, '016b')
要将您的数字转换为二进制补码字符串表示形式,您需要在将负数字符串化之前实际采用二进制补码:
format(num if num >= 0 else (1 << 16) + num, '016b')
或者采用 mod 65536
:
format(num % (1 << 16), '016b')
关于python - python中数字的补码,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/21871829/