LeetCode 332. Reconstruct Itinerary

LeetCode 332

因为给的这个题目是确保有解的,这样的话,从起点开始肯定是可以到达每个点,并且肯定只有一个终点。通过DFS的方式,我们可以找到这个终点,一旦不能再去其他的地方,我们可以把终点加入到我们的path里面进去,同时从图上去掉终点。回退到进入终点的点,看是否还能去其他地方,如果不能,也可以加入到这个path。如果中间点还可以去其他的地方,那么在加入path的时候,需要插入到去终点之前的位置。

    def findItinerary(self, tickets: List[List[str]]) -> List[str]:
        #保证字母序排序
        tickets.sort(key=lambda x:x[1])
        
        #建图
        graph = collections.defaultdict(list)
        for u, v in tickets:
            graph[u].append(v)

		#DFS
        itinerary, stack = [], [("JFK")]
        while stack:
            current = stack[-1]
            if current in graph and len(graph[current]) > 0:
                stack.append(graph[current].pop(0))
            else:
                itinerary.append(stack.pop())

        return itinerary[::-1]
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值