【C++】原码反码补码最简洁使用总结

一、有符号数和无符号数

有符号数: 范围( 0 ~ 15 ) 0000 = 0 ,1111 = 15。[总共16个数 ]
无符号数: 范围( -7~+7) 1111 = -7 ,1000 = -0,0000 = +0 ,0111 = +7;
[四位有符号数同样表示16个数,其中正负0表示两个数]

二、原码表示 (能满足同正号的数和无符号数相加,异号相加出错)

表示方法: 一中四位 8 4 2 1 和 ± ( 4 2 1)即为原码表示方法。
计 算: 0100(-4)+ 0100(-4) = 1000(-0) -8负向溢出一位即为 -0。

三、反码表示(解决异号相加问题,但是同负号相加错误)

 表示方法:正数时反码即为原码,负数时符号位不变,其余按位取反,如  2的原码为0010,反码仍
   为0010 ; -5的原码为  1101   反码为 1010 。

计 算: 1010(-5)+0010(2) = 1100 (反码取反为1011 ,即为-3)。

四、补码表示(解决所有计算问题)

表示方法:正数补码等于其本身;负数的反码两种方法【1、符号数和最后一个1以及1右边所有的0保持不变,其余按位取反】 【2、反码+1】,如 2的原码为0010,反码仍为0010 ; -5 原码为1101, 补码为1011。
计 算:1011(-5)+0010(2) = 1101 (原码表示为1011 ,即为-3)。

补码注意: 补码1000为 -8,因为符号位溢出被舍弃。本来补码表示为11000。所以其范围为[-8 ~ +7],不存在正负0的问题,仍表示16个不同的数。

你可能感兴趣的:(C++,补码)