mirror of
https://hub.njuu.cf/TheAlgorithms/Python.git
synced 2023-10-11 13:06:12 +08:00
Added largest pow of 2 le num (#9374)
This commit is contained in:
parent
0d324de7ab
commit
f3be0ae9e6
60
bit_manipulation/largest_pow_of_two_le_num.py
Normal file
60
bit_manipulation/largest_pow_of_two_le_num.py
Normal file
@ -0,0 +1,60 @@
|
||||
"""
|
||||
Author : Naman Sharma
|
||||
Date : October 2, 2023
|
||||
|
||||
Task:
|
||||
To Find the largest power of 2 less than or equal to a given number.
|
||||
|
||||
Implementation notes: Use bit manipulation.
|
||||
We start from 1 & left shift the set bit to check if (res<<1)<=number.
|
||||
Each left bit shift represents a pow of 2.
|
||||
|
||||
For example:
|
||||
number: 15
|
||||
res: 1 0b1
|
||||
2 0b10
|
||||
4 0b100
|
||||
8 0b1000
|
||||
16 0b10000 (Exit)
|
||||
"""
|
||||
|
||||
|
||||
def largest_pow_of_two_le_num(number: int) -> int:
|
||||
"""
|
||||
Return the largest power of two less than or equal to a number.
|
||||
|
||||
>>> largest_pow_of_two_le_num(0)
|
||||
0
|
||||
>>> largest_pow_of_two_le_num(1)
|
||||
1
|
||||
>>> largest_pow_of_two_le_num(-1)
|
||||
0
|
||||
>>> largest_pow_of_two_le_num(3)
|
||||
2
|
||||
>>> largest_pow_of_two_le_num(15)
|
||||
8
|
||||
>>> largest_pow_of_two_le_num(99)
|
||||
64
|
||||
>>> largest_pow_of_two_le_num(178)
|
||||
128
|
||||
>>> largest_pow_of_two_le_num(999999)
|
||||
524288
|
||||
>>> largest_pow_of_two_le_num(99.9)
|
||||
Traceback (most recent call last):
|
||||
...
|
||||
TypeError: Input value must be a 'int' type
|
||||
"""
|
||||
if isinstance(number, float):
|
||||
raise TypeError("Input value must be a 'int' type")
|
||||
if number <= 0:
|
||||
return 0
|
||||
res = 1
|
||||
while (res << 1) <= number:
|
||||
res <<= 1
|
||||
return res
|
||||
|
||||
|
||||
if __name__ == "__main__":
|
||||
import doctest
|
||||
|
||||
doctest.testmod()
|
Loading…
Reference in New Issue
Block a user