二进制原码 反码 补码的终极奥秘

文章探讨了在有符号位的二进制表示中,负数只有补码,求负数补码的原码相当于求其正数的原码。例如,-42的补码是11010110,而42的原码是00101010。通过取反加1的过程可以验证这一关系。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

首先看一下AI的权威解释

 于是我能这样理解

有符号位的讨论前提下,

  • 负数只拥有补码,求原码其实是求其正数的原码,负数的补码整体取反加1
  • 求一个负数的补码,是它正数的原码,符号位为1,剩下的位取反加1

给出一个列子用于理解上面的一段话

42的原码, 反码, 补码都是0010 1010

那么-42 的补码是多少呢?

符号位(原码的最高位)为1, 原码的剩下的位取反加1

-42的补码是                    1101 0110

如果知道一个负数的补码,好多资料中说是求这个负数的补码,我感觉这样说是不对的!

比如我求 -42补码的原码,整体取反加1 是0010 1010  是等于42正数的原码的。

所以我在最前面说负数只有补码,求它补码的原码其实是在求它正数的原码的!

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值