二进制补码运算法则,十进制数与二进制补码的相互转换?

2022-05-27 00:33:18 发布:网友投稿
热度:44

学了好长时间二进制补码运算法则,今天终于真正理解了计算机中负数的存储,终于理解了补码的运算!

1、补码的运算:

已知十进制求二进制

求正整数的二进制补码

除2取余,直到商为零,余数倒叙排列

求负整数的二进制

先求该负数绝对值的二进制代码,然后将二进制代码的所有位取反,再加1,然后在左边补1作为符号位。如果要求用更多的位来表示,则相应的在符号位的左边补1就行了。下面随便列举了一些数字,其他的相应模仿就行了:

负数:-5绝对值:5绝对值的二进制码:101二进制反码:010二进制补码:011左边再不一位1表示负数,即1011 = (-1)*8+0*4+1*2+1*1 = -5

补码8位表示:11111011 = (-1)*(2^7)+1*(2^6)+1*(2^5)+1*(2^4)…… = -5

补码16位16进制表示:FFFB = -5

以下的几个数的例子的计算过程同上: 负数:-14绝对值:14绝对值的二进制码:1110二进制反码:0001二进制补码:10010 = -14

补码8位16进制表示:F2 = -14

补码16位16进制表示:FFF2 = -14

负数:-27绝对值:27绝对值的二进制码:11011二进制反码:00100二进制补码:100101 = -27

补码8位16进制表示:E5 = -27

补码16位16进制表示:FFE5 = -27

负数:-79绝对值:79绝对值的二进制码:1001111二进制反码:0110000二进制补码:10110001

补码8位16进制表示:B1

补码16位16进制表示:FFB1

负数:-127绝对值:127绝对值的二进制码:1111111二进制反码:0000000二进制补码:10000001

补码8位16进制表示:81

补码16位16进制表示:FF81

负数:-128绝对值:128绝对值的二进制码:10000000二进制反码:01111111二进制补码:10000000

补码8位16进制表示:80

补码16位16进制表示:FF80

行啦,就举这么多,再多就啰嗦了。下面再说一下计算机中n位二进制补码的十进制表示范围。

2、n位二进制补码的十进制表示范围

8位二进制补码最大能表示的正整数应该是127,即二进制为01111111,其中最左边0为符号位,表示正数。8位二进制补码最小能表示的负整数应该是-128,即二进制为10000000,其中最左边1为符号位,表示负数,即(-1)*(2^7)。

其他的以此类推。

下一篇:吩咐的近义词是什么,“吩咐”的近义词是什么?
上一篇:院子蚊子太多怎么处理