负数二进制转换 位移运算问题负数二进制数怎么转换成十进制?如:1 1111100 = — 4,这是怎么转的?求方法- 20 >> 3 结果是 - 3,为什么?

来源:学生作业帮助网 编辑:作业帮 时间:2024/11/05 23:37:24
负数二进制转换 位移运算问题负数二进制数怎么转换成十进制?如:1 1111100 = — 4,这是怎么转的?求方法- 20  >> 3 结果是 - 3,为什么?
xSAN@quBPEp ۑ$ZJ* $(b'!wAǓU?3Vb ͳ[8H.:XAڟE#m-[nPGy\7Qo`c9;V1x~6,8aKnWb|R 

I'D}U~ܿoͺk9lPbtQ__莶^v.o81iz[lФhSb͉6ǚ0VdU*^"4|̰P FrҨi(:ʕ]/hdj'ߋuy§G#) X~jFg4ȓ}l&׎-L13jsq p G\ 1SP)f(9IА= cO>`@"v:-quqڙ'[6l6ahT(

负数二进制转换 位移运算问题负数二进制数怎么转换成十进制?如:1 1111100 = — 4,这是怎么转的?求方法- 20 >> 3 结果是 - 3,为什么?
负数二进制转换 位移运算问题
负数二进制数怎么转换成十进制?如:1 1111100 = — 4,这是怎么转的?求方法
- 20 >> 3 结果是 - 3,为什么?

负数二进制转换 位移运算问题负数二进制数怎么转换成十进制?如:1 1111100 = — 4,这是怎么转的?求方法- 20 >> 3 结果是 - 3,为什么?
似乎是 取反加一 也就是说要求负数,就是 用对应正数,取反+1
4 0000 0100 取反 1111 1011 +1后 1111 1100
3 0000 0011 取反 1111 1100 +1后 1111 1101
这种方法叫求补运算.负数转正数,也是进行取反+1 的求补运算
负数二进制转十进制,是对这个负数二进制进行求补运算,得到对应的正数,前面加个负号就得到对应的十进制了吧
20 0001 0100 进行求补运算 取反1110 1011 +1后 1110 1100 这就是-20的二进制
-20>>3 算术右移3位 1111 1101 变成这个 也就是-3 对应的二进制了
因为是负数,左边第一位是1,所以算术右移3位相当于左边加 3个 1,右边再减去3位 .