节点间通路[go 使用队列记录]

前言

在图中,寻找起点到目标点的步数/是否存在路径相关,bfs相对dfs更快,毕竟空间换时间了,双向bfs会更快一点,毕竟一层一层的扩展起来非常大,队列要存太多元素。

一、节点间的通路

在这里插入图片描述

二、go使用队列记录

1.go的队列库:container/list,list.New()获取队列,双向链表,可PushBack,也可PushFront,出队Front
2.队列中的元素是指针类型*Elem,想要得到其值x.Value,进一步断定类型,可.(ElemType)

func findWhetherExistsPath(n int, graph [][]int, start int, target int) bool {
    // 起点即终点
    if start == target {
        return true
    }
    // 把图用邻接表存起来。
    g := getNeiSheet(n,graph)
    // bfs寻找源点到目标点是否有路径。
    return bfs(start,target,g)
}
func bfs(s,t int,g []map[int]interface{}) bool {
    // 防止重复访问
    p := map[int]interface{}{}
    // 开辟队列
    que := list.New()
    que.PushBack(s)
    // 采用队列来进行“层次遍历”
    for x := que.Front();x != nil;x = x.Next() {
        // 找到了
        if v := x.Value.(int);v == t {
            return true
        }
        // 没有边
        v := x.Value.(int)
        if g[v] == nil {
            continue
        }
        // 下一波入队,不许重复。
        for k := range g[v] {
            if _,ok := p[k];!ok {
                que.PushBack(k)
                p[k] = struct{}{}
            }
        }
    }
    return false
}
func getNeiSheet(n int,edges [][]int) []map[int]interface{} {
    g := make([]map[int]interface{},n)

    for _,edge := range edges {
        a,b := edge[0],edge[1]
        if g[a] == nil {
            g[a] = map[int]interface{}{}
        }
        g[a][b] = struct{}{}
    }
    return g
}
// 找一个节点到另一个节点是否有路径,最快就是bfs

总结

1)在图中,寻找起点到目标点的步数/是否存在路径相关,bfs相对dfs更快,毕竟空间换时间了,双向bfs会更快一点,毕竟一层一层的扩展起来非常大,队列要存太多元素。

参考资料

[1] LeetCode 节点间通路

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值