332. Reconstruct Itinerary
Read the full problem statement on LeetCode.
Difficulty: hard Acceptance: 44% Topics: Depth-First Search, Graph, Eulerian Circuit
View full problem on LeetCode Reading material
Reference solution (spoiler · python)
# Time: O(|V| + |E|log|V|)
# Space: O(|V| + |E|)
# Hierholzer Algorithm
import collections
class Solution(object):
def findItinerary(self, tickets):
"""
:type tickets: List[List[str]]
:rtype: List[str]
"""
adj = collections.defaultdict(list)
for ticket in tickets:
adj[ticket[0]].append(ticket[1])
for x in adj.itervalues():
x.sort(reverse=True)
origin = "JFK"
result = []
stk = [origin]
while stk:
while adj[stk[-1]]:
stk.append(adj[stk[-1]].pop())
result.append(stk.pop())
result.reverse()
return result
# Time: O(t! / (n1! * n2! * ... nk!)), t is the total number of tickets,
# ni is the number of the ticket which from is city i,
# k is the total number of cities.
# Space: O(t)
import collections
class Solution2(object):
def findItinerary(self, tickets):
"""
:type tickets: List[List[str]]
:rtype: List[str]
"""
def route_helper(origin, ticket_cnt, graph, ans):
if ticket_cnt == 0:
return True
for i, (dest, valid) in enumerate(graph[origin]):
if valid:
graph[origin][i][1] = False
ans.append(dest)
if route_helper(dest, ticket_cnt - 1, graph, ans):
return ans
ans.pop()
graph[origin][i][1] = True
return False
graph = collections.defaultdict(list)
for ticket in tickets:
graph[ticket[0]].append([ticket[1], True])
for k in graph.keys():
graph[k].sort()
origin = "JFK"
ans = [origin]
route_helper(origin, len(tickets), graph, ans)
return ans
Solution from kamyu104/LeetCode-Solutions · MIT
Similar questions