-
Notifications
You must be signed in to change notification settings - Fork 892
/
problem_346.py
43 lines (33 loc) · 1 KB
/
problem_346.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
import sys
def get_city_map(flights):
city_map = dict()
for src, dst, fare in flights:
if dst not in city_map:
city_map[dst] = list()
city_map[dst].append((src, fare))
return city_map
def get_cheapest_fare(src, tgt, max_stops, city_map, total=0, stops=0):
if stops > max_stops:
return sys.maxsize
if src == tgt:
return total
new_tgt_fares = city_map[tgt]
possibilities = list()
for new_tgt, fare in new_tgt_fares:
poss = get_cheapest_fare(
src, new_tgt, max_stops, city_map, total + fare, stops + 1)
possibilities.append(poss)
return min(possibilities)
# Tests
flights = [
('JFK', 'ATL', 150),
('ATL', 'SFO', 400),
('ORD', 'LAX', 200),
('LAX', 'DFW', 80),
('JFK', 'HKG', 800),
('ATL', 'ORD', 90),
('JFK', 'LAX', 500),
]
city_map = get_city_map(flights)
assert get_cheapest_fare("JFK", "LAX", 3, city_map) == 440
assert get_cheapest_fare("JFK", "LAX", 0, city_map) == sys.maxsize