Python中实现真正的按位取反运算

文章面向对象:对原理和编程不大有兴趣,只是需要用python实现一些运算功能的非计算机学生或从业者。大佬慎看防止血压拉高

运算代码

x=~x&0xFF

num是一个不大于255的十进制正数(负数的我不需要,所以我也没研究)
计算结果也是十进制的数
&右边的0xFF会决定计算结果的比特位。如果要得到正确的计算结果,两边的数据比特位应该相同
例如1000对应的十六进制是0xFC17,16比特位的,这时候求反就应该改成

x=~x&0xFFFF

实例说明

例如求58的反:
在这里插入图片描述
当x大于255时,想要得到正确的数字,就要修改一下代码
把0xFF换成0xFFFF或者更高,取决于x这个数占用的比特位。
(C语言基础会讲的知识,数据精度问题)
总之就是&两边的比特位要对应
**如果&右边保持为0xFF,但x大于了255,得到的结果则只有低位(如下图)
**在这里插入图片描述而实际上1000取反应该得到的十六进制表示是 ‘0xFC 17’
把完整的16比特位的FC17截断剩下17
(之所以这里用十六进制表示,是因为&右边对应的是16进制,这样看会更清楚。实际上取反运算是根据二进制表示运行的,那些也不重要,反正知道可以这样算就OK啦!)

  • 2
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值