C语言----原码、反码、补码
本文以12和(-12)为例,简要介绍正数和负数的原码、反码、补码求解过程
(注:本文均以C语言中整数int所占4字节32位形式来求解!)
正数原码、反码、补码
1、求解方法:正数的原码 = 反码 = 补码!
2、例子:求解12的原码、反码和补码?
解:12对应的二进制形式为:1100;
原码:0000 0000 0000 0000 0000 0000 0000 1100;
反码:0000 0000 0000 0000 0000 0000 0000 1100;
补码:0000 0000 0000 0000 0000 0000 0000 1100;
负数原码、反码、补码
1、求解方法:
负数原码: 先求该数绝对值对应的原码,再将其最高位的符号位改为1即可;
负数反码:将它的原码形式除了最高位外,其他位上的数都取反,即:0变1,1变0;
负数补码:将它的反码加上1;
2、例子:求解(-12)的原码、反码和补码?
解:(-12)对应的绝对值是12,12的原码如下:
0000 0000 0000 0000 0000 0000 0000 1100;
再将上式最高位变为1即它的原码形式;
所以:
(-12)原码为:1000 0000 0000 0000 0000 0000 0000 1100;
反码由上述求解方法可得(除最高位外,其余0变1,1变0):
(-12)反码为:1111 1111 1111 1111 1111 1111 1111 0011;
补码为反码加1,即:
(-12)补码为:1111 1111 1111 1111 1111 1111 1111 0100;
519

被折叠的 条评论
为什么被折叠?



