Leetcode815.公交线路 Bus Routes(Java)

Leetcode815.公交线路 Bus Routes(Java)

##BFS##

广度优先搜索

2021-03 阿里春招题目

该题应该为图论题,边有权值的情况下寻找最短路径,采用多源BFS解决

示例 1:

输入:routes = [[1,2,7],[3,6,7]], source = 1, target = 6
输出:2
解释:最优策略是先乘坐第一辆公交车到达车站 7 , 然后换乘第二辆公交车到车站 6 。

  • 使用HashMap<Integer, LinkedList<Integer>> map保存每个站点经过的线路,例如示例1中(key = 7, value = [0,1])的键值对代表的是7号公交站点存在与公交线路0、1中
  • LinkedList<Integer> queue队列为BFS中遍历的辅助队列,存放每一层需要遍历的站点
  • 已示例1为例,BFS遍历第一层流程如下,初始化队列queue只有source = 1一个元素
    • 遍历队列中元素查询HashMap中包含站点1的所有线路,得线路0
    • 遍历线路0的所有站点j = 2,7
      • j == target,找到目标站点,返回结果
      • 对于所有非目标站点j,都为下一层需要遍历的节点,都需要进队列等待遍历
    • 遍历完第一层所有j后,代表的实际含义是从站点1出发,乘坐一辆公共汽车能够到达的所有站点j
    • 因此遍历完一层后,公交车计数器cnt++
  • 同样的遍历方法,遍历至结果出现或遍历结束为止
  • 因为图有环路,因此可能会发生遍历死循环,
    • 采用自动去重的HashSet<Integer> set来记录已经遍历过的线路
    • 如果使用HashSet<Integer> set记录已经遍历过的站点,最用一个用例会因为超时而不通过

时间复杂度: O ( M × N ) O(M\times N) O(M×N)

class Solution {
   
  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值