⭐️
# 題目敘述
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"
# 解題思路
# Solution
import java.util.ArrayList; | |
import java.util.HashMap; | |
import java.util.List; | |
import java.util.Map; | |
class Solution { | |
public String destCity(List<List<String>> paths) { | |
Map<String, Integer> map = new HashMap<>(); | |
ArrayList<String> tmp = new ArrayList<>(); | |
for(List<String> p : paths){ | |
String start = p.get(0); | |
String end = p.get(1); | |
map.put(start, map.getOrDefault(start, 0) + 1); | |
map.put(end, map.getOrDefault(end, 0) - 1); | |
if(map.get(start) == 0 && tmp.contains(start)) tmp.remove(start); | |
if(map.get(end) == -1) tmp.add(end); | |
} | |
return tmp.get(0); | |
} | |
} |
單字
** **
!! !!
片語 & 搭配詞
!! !!