编程语言
首页 > 编程语言> > 大话 Python:python 基础巩固 -- 位运算的奥妙

大话 Python:python 基础巩固 -- 位运算的奥妙

作者:互联网

watermark,size_16,text_QDUxQ1RP5Y2a5a6i,color_FFFFFF,t_100,g_se,x_10,y_10,shadow_90,type_ZmFuZ3poZW5naGVpdGk=

 

位运算是直接对内存中的二进制位进行操作,因此,它的运算效率相比一般的数学运算是比较高的。一般情况下,位运算主要分为六种:与运算、或运算、异或运算、取反运算、左移运算、右移运算。

在开始之前,先介绍一下将十进制转换成二进制的方法。为节约篇幅说明后面的内容,此处我们直接使用 python 内置的 bin() 函数将整数转换为二进制。

注意:若操作系统为32位,则二进制根据位数补全32位即可,以下用低位说明问题,如 10 的二进制计算出为 1010,则补全32位应为 00000000000000000000000000001010。

 

 1def toBin(num):
2   # 十进制转换成二进制
3   res = bin(int(num))
4   # 去掉前两位,因为内置函数转换后前面两个字符是0b
5   return res[2:]
6
7if __name__ == '__main__':
8   print toBin(10)
9   结果10的二进制是1010
10   print toBin(8)
11   结果8的二进制是1000
12   根据二进制“或”的计算规则:对应的两个二进位有一个为1时结果位就为1,否则为0
13   对比结果:1010 转为10进制也就是10
14   print 10 | 8
15   10
3、异或运算
 1def toBin(num):
2   # 十进制转换成二进制
3   res = bin(int(num))
4   # 去掉前两位,因为内置函数转换后前面两个字符是0b
5   return res[2:]
6
7if __name__ == '__main__':
8   print toBin(10)
9   结果10的二进制是1010
10   根据二进制“左移”的计算规则:将位数将左移动,遵循低位补0、高位丢弃
11   向左移动一位
12   对比结果:01010 转为10进制也就是20
13   print 10 << 1
14   20
6、右移运算watermark,size_16,text_QDUxQ1RP5Y2a5a6i,color_FFFFFF,t_100,g_se,x_10,y_10,shadow_90,type_ZmFuZ3poZW5naGVpdGk=

 

Python 集中营

分享编程技术、还原编程思想

watermark,size_16,text_QDUxQ1RP5Y2a5a6i,color_FFFFFF,t_100,g_se,x_10,y_10,shadow_90,type_ZmFuZ3poZW5naGVpdGk=

原创技术|编程实战|学习社区

 

watermark,size_16,text_QDUxQ1RP5Y2a5a6i,color_FFFFFF,t_100,g_se,x_10,y_10,shadow_90,type_ZmFuZ3poZW5naGVpdGk=

标签:__,10,toBin,运算,二进制,Python,python,print,--
来源: https://blog.51cto.com/u_14128936/2970866