一、概念
正数的原码、反码、补码均相同。
负数的情况如下:
- 原码:最高位为符号位,其余位使用该数值的绝对值表示。
- 反码:在原码的基础上,符号位不变,其他位均取反。
- 补码:反码+1,即在原码的基础上,符号位不变,其他位取反后+1。补码的补码为原码。因为X的补码是2^(n-1)-X的绝对值,最高位符号位为1的数的原码(n代表X的位数)。参考链接:补码本质
- 相同点:最高位均为符号位,1表示负数,0表示正数。
二、引入补码解决的问题
-
计算机中因符号位参与运算而得不到正确结果的现象,减法采用加法替代
例如:-1-127=-128
原码:1000,0001[原] - 0111,1111[原] = 0111,1110[原]=126
反码:1111,11110[反] - 0111,1111[反] = 0111,1110[反]=126
补码:1111,11111[补] - 0111,1111[补] = 1000,0000[补]=-128注意:1000,0000[补]转换成原码是2^7-0加上符号位1,即-128。
-
补码能多表示一个最