-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathdestination-city.py
executable file
·70 lines (58 loc) · 1.8 KB
/
destination-city.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
66
67
68
69
70
# -*- coding: utf-8 -*-
"""
Created on Sun May 3 03:52:18 2020
@author: johnoyegbite
"""
# SOLVED!
"""
Problem:
You are given the array paths, where paths[i] = [cityAi, cityBi] means
there exists a direct path going from cityAi to cityBi.
Return the destination city, that is, the city without any path outgoing
to another city.
It is guaranteed that the graph of paths forms a line without any loop,
therefore, there will be exactly one destination city.
Example 1:
Input: paths = [["London","New York"],["New York","Lima"],
["Lima","Sao Paulo"]]
Output: "Sao Paulo"
Explanation: Starting at "London" city you will reach "Sao Paulo" city
which is the destination city.
Your trip consist of: "London" -> "New York" -> "Lima" -> "Sao Paulo".
Example 2:
Input: paths = [["B","C"],["D","B"],["C","A"]]
Output: "A"
Explanation: All possible trips are:
"D" -> "B" -> "C" -> "A".
"B" -> "C" -> "A".
"C" -> "A".
"A".
Clearly the destination city is "A".
Example 3:
Input: paths = [["A","Z"]]
Output: "Z"
Constraints:
1 <= paths.length <= 100
paths[i].length == 2
1 <= cityAi.length, cityBi.length <= 10
cityAi != cityBi
All strings consist of lowercase and uppercase English letters and the space
character.
"""
class Solution:
def destCity(self, paths) -> str:
"""
type paths: List[List[str]]
rtype: str
"""
start = {}
dest = {}
for path in paths:
s, d = path
if s not in start:
start[s] = True
if d not in dest:
dest[d] = True
for city in dest:
if city not in start:
return city