云计算开发:Python练习实例-使用按位取反~

题目:学习使用按位取反~。说明:二进制数在内存中以补码的形式存储。按位取反:二进制每一位取反,0 变 1,1 变 0。最高位为符号位,正数的符号位为 0,负数为 1。

题目:学习使用按位取反~。

说明:

二进制数在内存中以补码的形式存储。

按位取反:二进制每一位取反,0 变 1,1 变 0。

最高位为符号位,正数的符号位为 0,负数为 1。

对正数来说,最高位为 0,其余各位代表数值本身(以二进制表示),如 +42 的补码为 00101010。

对负数而言,把该数绝对值的补码按位取反,然后对整个数加 1,即得该数的补码。如 -42 的补码为 11010110(00101010 按位取反

11010101+1 即 11010110)。

~9 的计算步骤:

202103311043

转为原码:

202103311044

程序源代码:

202103311045

以上实例输出结果为:

202103311046

说明:

~7,对 7 进行取反,7 的补码是 00000111 对补码取反得到 11111000,最高位 1 为符号位,表示负数,所以该补码对应的整数为 -8。

~-7 对 -7 进行取反,-7 的补码是 11111001 对补码取反得到 00000110,最高位 0 为符号位,表示正数,所以补码对应的整数为 6。

人已赞赏
云计算

字节跳动九周年张一鸣演讲全文:关注当下 平常心对待过去和未来

2021-3-31 10:30:25

云计算

高德车道级导航已上线8城 新增支持小米11Pro

2021-3-31 11:26:23

0 条回复 A文章作者 M管理员
    暂无讨论,说说你的看法吧
个人中心
购物车
优惠劵
今日签到
有新私信 私信列表
搜索