菜鸟算法-图的邻接表表示法

图的邻接表

上图中有4个顶点5条边:

起始顶点 目标顶点 权值 边编号
A B 9 1
D C 8 2
A B 5 3
B D 6 4
A C 7 5

邻接表

这里用数组来实现邻接表:

邻接表
  • U V W : U[i]->V[i] 权值为 W[i], 边编号为 i;
  • first: first[i] 表示 i(A, B, C, D)号顶点的第一条边;
  • next : next[i] 表示 i(1,2,3,4,5)号边的下一条边;

构建邻接表

看图不说话

1.png
2.png
3.png
4.png
5.png

// 顶点编号:0,1,2,3 表示顶点 A,B,C,D
// 边编号:0,1,2,3,4
var u = [5]int{0, 3, 0, 1, 0}
var v = [5]int{3, 2, 1, 3, 2}
var w = [5]int{9, 8, 5, 6, 7}

func AdjacencyList() ([4]int, [5]int) {

        for i := 0; i < 5; i++ {
                fmt.Println(u[i], " -> ", v[i], " ", w[i])
        }

        first := [4]int{-1, -1, -1, -1}
        next := [5]int{-1, -1, -1, -1, -1}

        fmt.Println("fisrt : ", first)
        fmt.Println("next: ", next)
        fmt.Println("-----------------------")

        // 遍历5条边
        for i := 0; i < 5; i++ {
                next[i] = first[u[i]] // 将第i条边的下一条边设置为 u[i]号顶点的当前第一条边
                first[u[i]] = i       // 将u[i]号顶点的第一条边设置为当前边
        }

        fmt.Println("first: ", first)
        fmt.Println("next: ", next)

        return first, next
}


结果

邻接表存储图的空间复杂度是O(M) (M边数),查找的时间复杂度也 为O(M)

遍历顶点的出边:

func TraverseEdge(point int, first [4]int, next [5]int) {
        k := first[point]
        for -1 != k {
                fmt.Println(u[k], " -> ", v[k], " ", w[k])
                k = next[k]
        }
}

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 第一章 绪论 什么是数据结构? 数据结构的定义:数据结构是相互之间存在一种或多种特定关系的数据元素的集合。 第二章...
    SeanCheney阅读 5,807评论 0 19
  • -DFS(Depth First Search):深度优先搜索 访问完一个顶点的所有邻接点之后,会按原路返回,对应...
    Spicy_Crayfish阅读 2,853评论 1 0
  • 十一月十九日, 是夜的颜色。 归途 我的心情, 不多不少, 刚刚好。
    一素心阅读 151评论 0 0
  • 前段时间,总结了一下如何生成二维码,如果想了解可以移步二维码的生成。下面我们进入正题。再说扫描二维码之前,我们先来...
    齐小天_Liu阅读 582评论 0 0