2020-09-11 12:16:43 +08:00
|
|
|
def bin_to_decimal(bin_string: str) -> int:
|
|
|
|
"""
|
|
|
|
Convert a binary value to its decimal equivalent
|
|
|
|
|
|
|
|
>>> bin_to_decimal("101")
|
|
|
|
5
|
|
|
|
>>> bin_to_decimal(" 1010 ")
|
|
|
|
10
|
|
|
|
>>> bin_to_decimal("-11101")
|
|
|
|
-29
|
|
|
|
>>> bin_to_decimal("0")
|
|
|
|
0
|
|
|
|
>>> bin_to_decimal("a")
|
2020-09-13 19:27:20 +08:00
|
|
|
Traceback (most recent call last):
|
2022-10-28 01:42:30 +08:00
|
|
|
...
|
2020-09-11 12:16:43 +08:00
|
|
|
ValueError: Non-binary value was passed to the function
|
|
|
|
>>> bin_to_decimal("")
|
2020-09-13 19:27:20 +08:00
|
|
|
Traceback (most recent call last):
|
2022-10-28 01:42:30 +08:00
|
|
|
...
|
2020-09-13 19:27:20 +08:00
|
|
|
ValueError: Empty string was passed to the function
|
2020-09-11 12:16:43 +08:00
|
|
|
>>> bin_to_decimal("39")
|
2020-09-13 19:27:20 +08:00
|
|
|
Traceback (most recent call last):
|
2022-10-28 01:42:30 +08:00
|
|
|
...
|
2020-09-11 12:16:43 +08:00
|
|
|
ValueError: Non-binary value was passed to the function
|
|
|
|
"""
|
|
|
|
bin_string = str(bin_string).strip()
|
|
|
|
if not bin_string:
|
|
|
|
raise ValueError("Empty string was passed to the function")
|
|
|
|
is_negative = bin_string[0] == "-"
|
|
|
|
if is_negative:
|
|
|
|
bin_string = bin_string[1:]
|
|
|
|
if not all(char in "01" for char in bin_string):
|
|
|
|
raise ValueError("Non-binary value was passed to the function")
|
|
|
|
decimal_number = 0
|
|
|
|
for char in bin_string:
|
|
|
|
decimal_number = 2 * decimal_number + int(char)
|
2020-09-13 19:27:20 +08:00
|
|
|
return -decimal_number if is_negative else decimal_number
|
2020-09-11 12:16:43 +08:00
|
|
|
|
|
|
|
|
|
|
|
if __name__ == "__main__":
|
|
|
|
from doctest import testmod
|
|
|
|
|
|
|
|
testmod()
|