python實現(xiàn)整數(shù)的二進制循環(huán)移位
題目:如何在python中實現(xiàn)整數(shù)的二進制循環(huán)移位?
概述
在python中,可以通過<<以及>>運算符實現(xiàn)二進制的左移位以及右移位,然而并沒有實現(xiàn)循環(huán)移位的運算符,暫時也找不到可以實現(xiàn)循環(huán)移位的函數(shù),所以在本文中,主要介紹了如何使用字符的切片運算實現(xiàn)循環(huán)位移。
一、實現(xiàn)思路
1、利用字符串的format函數(shù)將int整數(shù)值轉化為特定位數(shù)的二進制值
2、利用字符的切片操作實現(xiàn)循環(huán)位移
二、實現(xiàn)代碼
# left circular shift #int_value是輸入的整數(shù),k是位移的位數(shù),bit是整數(shù)對應二進制的位數(shù) def circular_shift_left (int_value,k,bit = 8): bit_string = '{:0%db}' % bit bin_value = bit_string.format(int_value) # 8 bit binary bin_value = bin_value[k:] + bin_value[:k] int_value = int(bin_value,2) return int_value # right circular shift def circular_shift_right (int_value,k,bit = 8): bit_string = '{:0%db}' % bit bin_value = bit_string.format(int_value) # 8 bit binary bin_value = bin_value[-k:] + bin_value[:-k] int_value = int(bin_value,2) return int_value if __name__ == "__main__": A=1 B=circular_shift_right(A, 1, 8) print(A,"右循環(huán)位移1位的結果是",B) C = 128 D =circular_shift_left(C,1,8) print(C, "左循環(huán)位移1位的結果是", D)
三、運行結果
以上就是本文的全部內(nèi)容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。
相關文章
Pandas數(shù)據(jù)結構中Series屬性詳解
本文主要介紹了Pandas數(shù)據(jù)結構中Series屬性詳解,文中通過示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下2022-04-04Python requests HTTP驗證登錄實現(xiàn)流程
這篇文章主要介紹了Python requests HTTP驗證登錄實現(xiàn)流程,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下2020-11-11