题目地址:https://leetcode-cn.com/problems/destination-city/
题目描述
给你一份旅游线路图,该线路图中的旅行线路用数组 paths
表示,其中 paths[i] = [cityAi, cityBi]
表示该线路将会从 cityAi
直接前往 cityBi
。请你找出这次旅行的终点站,即没有任何可以通往其他城市的线路的城市。
题目数据保证线路图会形成一条不存在循环的线路,因此只会有一个旅行终点站。
示例1:
输入:paths = [["London","New York"],["New York","Lima"],["Lima","Sao Paulo"]]
输出:"Sao Paulo"
解释:从 "London" 出发,最后抵达终点站 "Sao Paulo" 。本次旅行的路线是 "London" -> "New York" -> "Lima" -> "Sao Paulo" 。
示例2:
输入:paths = [["B","C"],["D","B"],["C","A"]]
输出:"A"
解释:所有可能的线路是:
"D" -> "B" -> "C" -> "A".
"B" -> "C" -> "A".
"C" -> "A".
"A".
显然,旅行终点站是 "A" 。
示例3:
输入:paths = [["A","Z"]]
输出:"Z"
提示:
1、 1<=paths.length<=100
;
2、 paths[i].length==2
;
3、 1<=cityAi.length,cityBi.length<=10
;
4、 cityAi!=cityBi
;
5、 所有字符串均由大小写英文字母和空格字符组成;
题目大意
给出的是一个有向无环图,找出旅行的终点站。
解题方法
set
第一个感觉是 拓扑排序,但这个是周赛的 Easy 题,应该很简单。
注意题目给出的条件:只会有一个旅行终点站。
所以,我们找出 哪个站 没有出度就行了。说人话:只有一个站不会出现在出发点上。
所以,对所有的站进行统计,如果一个站没有出现在出发点上,那这个站就是最终的旅行终点站。
Python 代码如下:
class Solution(object):
def destCity(self, paths):
"""
:type paths: List[List[str]]
:rtype: str
"""
starts = set()
ends = set()
for path in paths:
starts.add(path[0])
ends.add(path[1])
for end in ends:
if end not in starts:
return end
return ""
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15
DDKK.COM 弟弟快看-教程,程序员编程资料站,版权归原作者所有
本文经作者:负雪明烛 授权发布,任何组织或个人未经作者授权不得转发