本文介紹了如何修改整數(shù)中的位?的處理方法,對大家解決問題具有一定的參考價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)吧!
問題描述
我有一個值為 7
(0b00000111
) 的整數(shù),我想用 13
(>0b00001101
).替換整數(shù)中的位的最佳算法是什么?
I have an integer with a value 7
(0b00000111
) And I would like to replace it with a function to 13
(0b00001101
). What is the best algorithm to replace bits in an integer?
例如:
set_bits(somevalue, 3, 1) # What makes the 3rd bit to 1 in somevalue?
推薦答案
這些適用于任何大小的整數(shù),甚至大于 32 位:
These work for integers of any size, even greater than 32 bit:
def set_bit(value, bit):
return value | (1<<bit)
def clear_bit(value, bit):
return value & ~(1<<bit)
如果你喜歡簡短的東西,你可以使用:
If you like things short, you can just use:
>>> val = 0b111
>>> val |= (1<<3)
>>> '{:b}'.format(val)
'1111'
>>> val &=~ (1<<1)
'1101'
這篇關(guān)于如何修改整數(shù)中的位?的文章就介紹到這了,希望我們推薦的答案對大家有所幫助,也希望大家多多支持html5模板網(wǎng)!
【網(wǎng)站聲明】本站部分內(nèi)容來源于互聯(lián)網(wǎng),旨在幫助大家更快的解決問題,如果有圖片或者內(nèi)容侵犯了您的權(quán)益,請聯(lián)系我們刪除處理,感謝您的支持!