C语言——二进制(原码、反码、补码)

整型占4个字节(32个bit)

#include<stdio.h>
int main()
{int a=10;
//00000000000000000000000000001010——原码
//00000000000000000000000000001010——反码
//00000000000000000000000000001010——补码
int b=-10;
//10000000000000000000000000001010——原码
原码——>补码:取反加一
//11111111111111111111111111110101——反码
//11111111111111111111111111110110——补码
return 0;
}

按照一个数的正负,直接写出它的二进制表现形式得到的就是原码。

内存中存储的是二进制的补码。

二进制的最高位为符号位,0表示正数,1表示负数。

正数 与 无符号数 的原码、反码、补码相同。

负数的原码、反码、补码要经过计算得到:

反码可由原码 符号位不变其它位按位取反得到。

补码可由反码+1得到。

公式:原码→补码:取反加一

           补码→原码:取反加一/减一取反(都可以)

猜你喜欢

转载自blog.csdn.net/outdated_socks/article/details/129456476