2 liushuguang liushuguang 于 2014.07.29 17:02 提问

位取反操作是否可以用这个方法口算?

最近学习PHP过程中,遇到一节课很有意思,就是按位取反操作
baidu来的说法是酱紫的
-------------引用开始
首先要知道,在计算机中,负数以其正值的补码形式表达。
这样我们就要知道三个概念了,原码,反码和补码。
原码:一个整数,按照绝对值大小转换成的二进制数,称为原码。
反码:将二进制数按位取反,所得的新二进制数称为原二进制数的反码。取反操作指:1变0, 0变1。
补码:反码加1称为补码。也就是说,要得到一个数的补码,先得到反码,然后将反码加上1,所得数称为补码。
正数的补码与其原码相同;负数的补码是在其反码的末位加1
-------------引用结束
经过半天的折磨,终于搞清楚怎么算了,但是发现这样真心麻烦,0101写的比较累,经过观察,貌似可以这样做:
即:假设A为原来的整数,则~A = -|A + 1|
请教这么做是否正确

1个回答

pardream
pardream   2014.07.29 17:15

A=-1就不正确。
正确的做法:2的(字长次方)- |A的绝对值|

比如:A=-2, |A|=2
8位的CPU,就是2的8次方-|A| = 254 , FE
16位CPU, 2的16次方-|A| = 65534, FFFE

Csdn user default icon
上传中...
上传图片
插入图片
准确详细的回答,更有利于被提问者采纳,从而获得C币。复制、灌水、广告等回答会被删除,是时候展现真正的技术了!