为什么-x = ~x + 1呢?

为什么-x = ~x + 1呢?

二进制补码(two's complement):

公式:

B2T(X)=-{ x_{w-1} * {2^{w-1}} + \sum_{i=0}^{w-2}x_i*2^i}

例子:

其实举个简单的例子就是

10=01010=2^{-4}+2^{3}+2^{2}+2^{1}+2^{0}

第4位第3位第2位第1位第0位
2^{-4}2^{3}2^{2}2^{1}2^{0}
-168421
01010

~运算符:

最简单的非运算就是翻转每一位,如果这一位是1翻转成0,如果是0翻转成1

~01101001
10010110

讨论:

这个时候如果

x=011110_2

那么

\sim x = 100001_2

那么我们把两个数相加,我们可以发现因为x和~x正好的是每一位都相反的,所以相加之后正好是1111..._2,在二进制补码的表示下就是-1。

所以将一个变量和它的取反变量相加,必然等于-1

x+\sim x = 111111_2=-1_{10}

x = -1- \sim x

所以得出结论

-x = \sim x + 1

 

评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

YifengGuo233

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值