-
Notifications
You must be signed in to change notification settings - Fork 96
/
124.py
36 lines (26 loc) · 864 Bytes
/
124.py
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
"""
Problem:
You have 100 fair coins and you flip them all at the same time. Any that come up tails
you set aside. The ones that come up heads you flip again. How many rounds do you
expect to play before only one coin remains?
Write a function that, given 'n', returns the number of rounds you'd expect to play
until one coin remains.
"""
from math import log2, ceil
def expectation(n: int) -> int:
# since the number of coins is expected (mean) to be halved on each toss, we use
# log2
# ceil is used to round it off to the next larger integer as number of tosses
# cannot be a fraction
return ceil(log2(n + 1))
if __name__ == "__main__":
print(expectation(0))
print(expectation(1))
print(expectation(2))
print(expectation(100))
print(expectation(200))
"""
SPECS:
TIME COMPLEXITY: O(1)
SPACE COMPLEXITY: O(1)
"""