当前位置: 移动技术网 > IT编程>脚本编程>Python > 4.Python 进制和位运算

4.Python 进制和位运算

2019年12月23日  | 移动技术网IT编程  | 我要评论

芙蓉王妃19楼,清流灵台山,狂暴警察

 

一、二进制转换

in [1]:
a = 3
print(bin(a))   #bin()转换为二进制
 
0b11
in [2]:
b = 0b10
print(int(b))  #int()转换为十进制
 
2
 

负数的二进制

求-5的二进制表示

step1:先求正数的二进制。5->0000 0101

step2:取反。 1111 1010

step3:反码加1。 1111 1011

 

二、位运算

与:  &
或:  |
非:  !
异或:^
左移:<<
右移:>>
in [3]:
print(3 & 2)  # 0000 0011 & 0000 0010 = 0000 0010
 
2
in [4]:
print(5 | 3) # 0000 0101 | 0000 0011 = 0000 0111
 
7
in [5]:
print(~5)   # ~0000 0101 = 1111 1010  看第一位符号位,为1是负数。取反:0000 0101 加1:0000 0110
 
-6
in [6]:
print(~10)  # ~0000 1010 = 1111 0101                             取反:0000 1010 加1:0000 1011
 
-11
in [7]:
print(~3)   # ~0000 0011 = 1111 1100                             取反:0000 0011 加1:0000 0100
 
-4
in [8]:
print(3^5) # 0000 0011 ^ 0000 0101 = 0000 0110
 
6
 

左移n位相当于乘以2的n次方

in [9]:
print(2<<1) # 0000 0010 << 1 = 0000 0100   
 
4
 

右移n位相当于除以2的n次方

in [10]:
print(2>>1) # 0000 0010 >> 1 = 0000 0001 
 
1

如对本文有疑问,请在下面进行留言讨论,广大热心网友会与你互动!! 点击进行留言回复

相关文章:

验证码:
移动技术网