计算机中的原码、反码和补码

本文将讲述计算机中原码、反码和补码的计算以及他们存在的意义

一、原码、反码和补码的计算

1、原码的计算
计算机中一般都是八位二进制表示数据。一个数的原码是:(符号位)+(数的绝对值的二进制表示),其中负数的符号位为1,正数的符号位为0

举例说明:

十进制原码
850101 0101
-851101 0101

2、反码的计算
正数的反码是其本身,负数的反码是在其原码的基础上,符号位不变,其余的各个位取反。

举例说明:

十进制原码反码
850101 01010101 0101
-851101 01011010 1010

3、补码的计算
正数的补码就是其本身,负数的补码是在其反码加1

举例说明:

十进制原码反码补码
850101 01010101 01010101 0101
-851101 01011010 10101010 1011

二、原码、反码和补码的意义

因为计算机做擅长做加法,所以人们就想如何把减法做成加法,这就是补码产生的原因

反码存在的意义在于算出补码。
而补码的意义在于:通过补码运算,可以把减法运算变成加法运算;而乘法可以用加法来做,除法可以转变成减法。
举个例子:
[ 52]原码: 0 0 1 1 0 1 0 0
[-52]反码: 1 1 0 0 1 0 1 1
[-52]补码: 1 1 0 0 1 1 0 0
这样当52加-52的时候就可以做如下加法:
   0 0 1 1 0 1 0 0
+ 1 1 0 0 1 1 0 0
----------------------------
   0 0 0 0 0 0 0 0
就完成了等于零的操作了

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值