-
-
Notifications
You must be signed in to change notification settings - Fork 50.5k
Expand file tree
/
Copy pathis_even.py
More file actions
40 lines (35 loc) · 1016 Bytes
/
is_even.py
File metadata and controls
40 lines (35 loc) · 1016 Bytes
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
def is_even(number: int) -> bool:
"""Return True if the input integer is even using a bitwise check.
Explanation:
In binary, even numbers always have the least significant bit cleared (0),
while odd numbers have it set (1). Therefore, ``n & 1 == 0`` implies even.
>>> is_even(1)
False
>>> is_even(4)
True
>>> is_even(9)
False
>>> is_even(15)
False
>>> is_even(40)
True
>>> is_even(100)
True
>>> is_even(101)
False
>>> is_even(True)
Traceback (most recent call last):
...
TypeError: input must be an integer
>>> is_even(3.14)
Traceback (most recent call last):
...
TypeError: input must be an integer
"""
if not isinstance(number, int) or isinstance(number, bool):
# bool is a subclass of int; explicitly disallow it as a number here.
raise TypeError("input must be an integer")
return (number & 1) == 0
if __name__ == "__main__":
import doctest
doctest.testmod()