我写的代码将有负数和正数,所有16位长,其中MSB是符号aka 2的补码。这意味着我能得到的最小数是-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
如果你在做类似的事情
要将数字转换为2的补码字符串表示形式,您需要在串接负数之前实际取负数的2补码:
或者改成
65536
:如果你真的想用16位存储数字,你可以使用struct。
可以使用
unpack
解包一个值的二补是一补加一。
基于此,您可以编写自己的转换函数:
结果如下:
编辑:要显示前面没有减号的位,可以使用以下功能:
相关问题 更多 >
编程相关推荐