mirror of
https://github.com/TheAlgorithms/Python.git
synced 2025-01-18 00:07:00 +00:00
Add function for highest set bit location (#7586)
* Add function for highest set bit location * Address review comments
This commit is contained in:
parent
74325d079c
commit
b46b92a916
34
bit_manipulation/highest_set_bit.py
Normal file
34
bit_manipulation/highest_set_bit.py
Normal file
|
@ -0,0 +1,34 @@
|
|||
def get_highest_set_bit_position(number: int) -> int:
|
||||
"""
|
||||
Returns position of the highest set bit of a number.
|
||||
Ref - https://graphics.stanford.edu/~seander/bithacks.html#IntegerLogObvious
|
||||
>>> get_highest_set_bit_position(25)
|
||||
5
|
||||
>>> get_highest_set_bit_position(37)
|
||||
6
|
||||
>>> get_highest_set_bit_position(1)
|
||||
1
|
||||
>>> get_highest_set_bit_position(4)
|
||||
3
|
||||
>>> get_highest_set_bit_position(0)
|
||||
0
|
||||
>>> get_highest_set_bit_position(0.8)
|
||||
Traceback (most recent call last):
|
||||
...
|
||||
TypeError: Input value must be an 'int' type
|
||||
"""
|
||||
if not isinstance(number, int):
|
||||
raise TypeError("Input value must be an 'int' type")
|
||||
|
||||
position = 0
|
||||
while number:
|
||||
position += 1
|
||||
number >>= 1
|
||||
|
||||
return position
|
||||
|
||||
|
||||
if __name__ == "__main__":
|
||||
import doctest
|
||||
|
||||
doctest.testmod()
|
Loading…
Reference in New Issue
Block a user