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