Python 基础教程:位运算的奥妙
生活随笔
收集整理的這篇文章主要介紹了
Python 基础教程:位运算的奥妙
小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
位運算是直接對內存中的二進制位進行操作,因此,它的運算效率相比一般的數學運算是比較高的。一般情況下,位運算主要分為六種:與運算、或運算、異或運算、取反運算、左移運算、右移運算。
在開始之前,先介紹一下將十進制轉換成二進制的方法。為節約篇幅說明后面的內容,此處我們直接使用 python 內置的 bin() 函數將整數轉換為二進制。
注意:若操作系統為32位,則二進制根據位數補全32位即可,以下用低位說明問題,如 10 的二進制計算出為 1010,則補全32位應為 00000000000000000000000000001010。
def toBin(num):# 十進制轉換成二進制res = bin(int(num))# 去掉前兩位,因為內置函數轉換后前面兩個字符是0breturn res[2:]if __name__ == '__main__':print toBin(10)1、與運算
def toBin(num):# 十進制轉換成二進制res = bin(int(num))# 去掉前兩位,因為內置函數轉換后前面兩個字符是0breturn res[2:]if __name__ == '__main__':print toBin(10)#結果10的二進制是1010print toBin(8)#結果8的二進制是1000#根據二進制“與”的計算規則:兩個數的相同位都為1時則對比結果為1,否則為0#對比結果:1000 轉為10進制也就是8print 10 & 882、或運算
''' 遇到問題沒人解答?小編創建了一個Python學習交流QQ群:531509025 尋找有志同道合的小伙伴,互幫互助,群里還有不錯的視頻學習教程和PDF電子書! ''' def toBin(num):# 十進制轉換成二進制res = bin(int(num))# 去掉前兩位,因為內置函數轉換后前面兩個字符是0breturn res[2:]if __name__ == '__main__':print toBin(10)#結果10的二進制是1010print toBin(8)#結果8的二進制是1000#根據二進制“或”的計算規則:對應的兩個二進位有一個為1時結果位就為1,否則為0#對比結果:1010 轉為10進制也就是10print 10 | 8103、異或運算
def toBin(num):# 十進制轉換成二進制res = bin(int(num))# 去掉前兩位,因為內置函數轉換后前面兩個字符是0breturn res[2:]if __name__ == '__main__':print toBin(10)#結果10的二進制是1010print toBin(8)#結果8的二進制是1000#根據二進制“異或”的計算規則:兩個對應的二進位相異時結果為1,否則為0#對比結果:0010 轉為10進制也就是2print 10 ^ 824、取反運算
''' 遇到問題沒人解答?小編創建了一個Python學習交流QQ群:531509025 尋找有志同道合的小伙伴,互幫互助,群里還有不錯的視頻學習教程和PDF電子書! ''' # 正數按位取反 def toBin(num):# 十進制轉換成二進制res = bin(int(num))# 去掉前兩位,因為內置函數轉換后前面兩個字符是0breturn res[2:]if __name__ == '__main__':print toBin(10)#結果10的二進制是1010#根據二進制“正數取反”的計算規則:首先 10 為正數它的補碼應該為 01010,#緊接著按位取反為 10101,再轉為原碼為 11010,再對原碼加1為11011,則最后結果為 -11print ~10-11#也可以直接使用公式計算:~10 = -(10 + 1)5、左移運算
''' 遇到問題沒人解答?小編創建了一個Python學習交流QQ群:531509025 尋找有志同道合的小伙伴,互幫互助,群里還有不錯的視頻學習教程和PDF電子書! ''' def toBin(num):# 十進制轉換成二進制res = bin(int(num))# 去掉前兩位,因為內置函數轉換后前面兩個字符是0breturn res[2:]if __name__ == '__main__':print toBin(10)#結果10的二進制是1010#根據二進制“左移”的計算規則:將位數將左移動,遵循低位補0、高位丟棄#向左移動一位#對比結果:01010 轉為10進制也就是20print 10 << 1206、右移運算
def toBin(num):# 十進制轉換成二進制res = bin(int(num))# 去掉前兩位,因為內置函數轉換后前面兩個字符是0breturn res[2:]if __name__ == '__main__':print toBin(10)#結果10的二進制是1010#根據二進制“右移”的計算規則:將位數向右移動,遵循低位丟棄、高位補0或補1(正數補0、負數補1)#向右移動一位#對比結果:0101 轉為10進制也就是5print 10 >> 15總結
以上是生活随笔為你收集整理的Python 基础教程:位运算的奥妙的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: Python笔记:日期时间获取与转换
- 下一篇: Python基础教程:数据结构