原码,是由一串01序列构成,首位代表符号位,0为正,1为负
eg. 0110 代表+6 1001 代表-1 1000代表-0(也就是0) 0000代表+0(也就是0)
我们不难发现,0可以由0000和1000表示,这样其实是有点浪费了一种状态,还有原码的相加减,并不能直接的相加减,比如0101+1101,如果按照我们正常的加减
由于寄存器最高只能存4位,图中是5位了,所以最高位会丢失,即为0010=2,但是正确的结果应该是等于0,所以我们可以发现,原码中如果包含了负数,很难直接相加减,我们必须通过取绝对值,判断绝对值大小的情况去计算,由此为了便于计算,我们引入了补码
正值的原码和补码一致
负值的补码有一个口诀:符号位不变,其他按位取反,再+1
eg. -5的补码是:先写出-5的原码:10000101,然后符号位不变,即首位1不变,剩下的按位取反,即0变成1,1变成0,为1111 1010+1=1111 1011
我们回到刚开始的问题,我们依然来计算0101+1101,首先1101的补码是1011
最高位舍弃,所以是0000,答案正确啦~