-
Notifications
You must be signed in to change notification settings - Fork 97
/
Copy path041.py
65 lines (52 loc) · 2.17 KB
/
041.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
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
"""
Problem:
Given an unordered list of flights taken by someone, each represented as
(origin, destination) pairs, and a starting airport, compute the person's itinerary. If
no such itinerary exists, return null. If there are multiple possible itineraries,
return the lexicographically smallest one. All flights must be used in the itinerary.
For example, given the list of flights
[('SFO', 'HKO'), ('YYZ', 'SFO'), ('YUL', 'YYZ'), ('HKO', 'ORD')] and starting airport
'YUL', you should return the list ['YUL', 'YYZ', 'SFO', 'HKO', 'ORD'].
Given the list of flights [('SFO', 'COM'), ('COM', 'YYZ')] and starting airport 'COM',
you should return null.
Given the list of flights [('A', 'B'), ('A', 'C'), ('B', 'C'), ('C', 'A')] and starting
airport 'A', you should return the list ['A', 'B', 'C', 'A', 'C'] even though
['A', 'C', 'A', 'B', 'C'] is also a valid itinerary. However, the first one is
lexicographically smaller.
"""
from typing import List, Optional, Tuple
def get_itinerary(
flights: List[Tuple[str, str]],
current_position: str,
current_itinerary: List[str] = [],
) -> Optional[List[str]]:
if not flights and current_itinerary:
return current_itinerary + [current_position]
elif not flights:
return None
resulatant_itinerary = None
# generating the itinerary
for index, (src, dest) in enumerate(flights):
# the is constructed using the current position (using DFS)
if current_position == src:
child_itinerary = get_itinerary(
flights[:index] + flights[index + 1 :], dest, current_itinerary + [src]
)
if child_itinerary and (
not resulatant_itinerary or child_itinerary < resulatant_itinerary
):
resulatant_itinerary = child_itinerary
return resulatant_itinerary
if __name__ == "__main__":
print(
get_itinerary(
[("SFO", "HKO"), ("YYZ", "SFO"), ("YUL", "YYZ"), ("HKO", "ORD")], "YUL"
)
)
print(get_itinerary([("SFO", "COM"), ("COM", "YYZ")], "COM"))
print(get_itinerary([("A", "B"), ("A", "C"), ("B", "C"), ("C", "A")], "A"))
"""
SPECS:
TIME COMPLEXITY: O(n ^ 3)
SPACE COMPLEXITY: O(n ^ 2)
"""