-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy path291.py
50 lines (38 loc) · 1.19 KB
/
291.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
37
38
39
40
41
42
43
44
45
46
47
48
49
"""
Problem:
An imminent hurricane threatens the coastal town of Codeville. If at most two people
can fit in a rescue boat, and the maximum weight limit for a given boat is k,
determine how many boats will be needed to save everyone.
For example, given a population with weights [100, 200, 150, 80] and a boat limit of
200, the smallest number of boats required will be three.
"""
from typing import List
def calculate_boats(arr: List[int], k: int) -> int:
length = len(arr)
arr.sort()
ptr1 = 0
ptr2 = length - 1
result = 0
while ptr1 < ptr2:
if arr[ptr2] > k:
# weight greater than boat weight limit
raise ValueError(f"Cannot accomodate {arr[ptr2]} within limit of {k}")
elif arr[ptr2] + arr[ptr1] > k:
# 2 people CANNOT be accomodated in 1 boat
result += 1
ptr2 -= 1
else:
# 2 people CAN be accomodated in 1 boat
result += 1
ptr1 += 1
ptr2 -= 1
if ptr1 == ptr2:
result += 1
return result
if __name__ == "__main__":
print(calculate_boats([100, 200, 150, 80], 200))
"""
SPECS:
TIME COMPLEXITY: O(n log(n))
SPACE COMPLEXITY: O(1)
"""