负数二进制补码的推导

本文详细解析了负数原码转化为补码的过程,包括取反和加一的步骤,并通过实例展示了负数补码求原码的方法。同时提供了几个关键的例子来辅助理解。

今天在看MIT公开课【编程范式】的时候发现二进制码补码只是不是很清楚,于是推一下


负数 原码 推 补码

注:t(原码),a(反码),c(补码) 

拿15举例   15:   00000000 00001111 (t)

要推出-15 ,因为   15 + (-15)= 0

15:00000000 00001111 ,0 :00000000 00000000

所以-15:

 00000000 00001111

       +

                          ?  (-15)

       =

 00000000 00000000    

因为:

       11111111 11111111 + 1 = 00000000 00000000 

所以我们先算出和为11111111 11111111的数,然后+1即可,也就是下面的a

 00000000 00001111

       +

                          a  

       =

 11111111 11111111

即:

    00000000 00001111 各位取反:11111111 11110000(a,其实就是反码)

于是:

 00000000 00001111

       +

          11111111 11110000(a)

       =

 11111111 11111111

而a + 1 ,即 11111111 11110001 ,也就是与15相加得0的值

于是就可得出:

 00000000 00001111

       +

          11111111 11110001 (c)

       =

 00000000 00000000

而c 就是负数的补码

            (取反)      

负数原码求补码     t --------> a  ------> a+1    =  c

            (取反)      

负数补码求原码同理 c -------> c反 ------> c反+1  =  t 

对于有符号的整数:

          原码t    反码a    补码c 

正数  47  00101111  00101111  00101111

负数  -47  10101111  11010000  11010001

看两个例子:

- 38 + 25 = -13

原码:

    -38: 10100110 

+

     25:00011001

补码:

    -38:11011010

+

     25: 00011001

=  

    -13: 11110011(补码)->10001101(原码)

        

 38 - 25 = 13

原码:

     38: 00100110

+

    -25:10011001     

         

补码:

     38: 00100110

+

    -25:11100111

=  

     13: 00001101(补码)->00001101(原码)

转载于:https://www.cnblogs.com/cykun/archive/2011/08/21/2147788.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值