liushuguang 2014-07-29 09:02 采纳率: 0%
浏览 1947

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

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

  • 写回答

1条回答

  • 中年風雨 2014-07-29 09:15
    关注

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

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

    评论

报告相同问题?

悬赏问题

  • ¥15 微信公众号自制会员卡没有收款渠道啊
  • ¥15 stable diffusion
  • ¥100 Jenkins自动化部署—悬赏100元
  • ¥15 关于#python#的问题:求帮写python代码
  • ¥20 MATLAB画图图形出现上下震荡的线条
  • ¥15 关于#windows#的问题:怎么用WIN 11系统的电脑 克隆WIN NT3.51-4.0系统的硬盘
  • ¥15 perl MISA分析p3_in脚本出错
  • ¥15 k8s部署jupyterlab,jupyterlab保存不了文件
  • ¥15 ubuntu虚拟机打包apk错误
  • ¥199 rust编程架构设计的方案 有偿