图论

简介: 图论

图论 最小生成树相关概念

  • 连通图:在无向图中,若任意两个顶点vivi与vjvj都有路径相通,则称该无向图为连通图。
  • 强连通图:在有向图中,若任意两个顶点vivi与vjvj都有路径相通,则称该有向图为强连通图。
  • 连通网:在连通图中,若图的边具有一定的意义,每一条边都对应着一个数,称为权;权代表着连接连个顶点的代价,称这种连通图叫做连通网。
  • 生成树: 一个连通图的生成树是指一个连通子图,它含有图中全部n个顶点,但只有足以构成一棵树的n-1条边。一颗有n个顶点的生成树有且仅有n-1条边,如果生成树中再添加一条边,则必定成环。
  • 最小生成树:在连通网里面,代价最小的生成树便是最小生成树

最小生成树(Prim&Kruskal)

  • 实例:如电路网怎么建设成本最低
  • Prim(普里姆)算法
  • Prim算法可以称为加点法,每次选择代价最小的边的点,从任一顶点开始,直至覆盖所有点
  • 算法思想:贪心
  • 算法流程:
  • 令图的所有顶点集合位V;初始令集合u={s},v=V−u
  • 寻找集合u,v中可以组成最小权重边(u0,v0)并且加入到集合u中
  • 重复上述步骤,直到生成n-1条边或者n个顶点为止
  • 普里姆算法如图:
  • Kruskal(克鲁斯卡尔)算法
  • Kruskal算法可以成为加边法,初始的生成边数为0,每次迭代选择最小代价的边,加入到最小生成树的边集合里面
  • 算法思想:贪心
  • Kruskal算法流程:
  • 将图的所有边按照代价从小到大进行排序
  • 将图中的n个顶点看成n个树构成的森林
  • 按照权值从小到大选择边,所选的边的两个顶点应该属于独立的树,则将它们连接成一棵树
  • 重复第三步,直到全部顶点都属于一棵树,或者有n-1条边为止
  • 克鲁斯卡尔算法流程:
  • Prim算法对于点操作,适用于稠密图;Kruskal算法对边进行操作,适用于稀疏图

最短路径

  • 路径长度:指路径所经历的边的数目
  • 带权路径长度:指路径所经过的边的权值之和
  • 最短路径:指带权路径值最小的路径

最短路径(Dijkstra&Floyd)

  • Dijkstra(迪杰斯特拉算法):
  • 用于求某点到其余各点的最短路径(只能计算权值大于0的边)
  • 算法思想:
  • 贪心思想
  • 设存在顶点集合U、T;U中包含了已经确定的最小权值路径的点,T中包含未确定的最小权值路径的点
  • 初始状态时:U中只包含了U0源点
  • 接下来从T中选择距离U0权值最小的点,加入U中
  • 集合U中每新增一个节点,都需要刷新U0到T中剩余元素的最小权值;新增加的U节点权值为原先权值与新增加U之后的节点的最小值
  • 重复3、4步骤,直到T中的所有节点在U中
  • 算法流程图:
  • Floyd(弗洛伊德算法):
  • 用于计算每一对顶点之间的最短距离
  • 算法思想:
  • 弗洛伊德算法的核心是DP,dp[i][j]=Math.min(dp[i][j],dp[i][k]+dp[k][j]);
  • 弗洛伊德算法模板:

   

//k为中转节点
        for(int k = 1; k <= n; k++)
            //i为开始节点
            for(int i = 1; i <= n; i++)
                //j为结束节点
                for(int j = 1; j <= n; j++)
                    //以k中间节点,求i至j的最低代价
                    if(a[i][j] > a[i][k]+a[k][j])
                        a[i][j] = a[i][k]+a[k][j];

  • Floyd算法流程:image.png
目录
相关文章
|
存储 算法 索引
数据结构与算法之图论及其相关算法
图的基本介绍 线性表局限于一个直接前驱和一个直接后继的关系,树也只能有一个直接前驱也就是父节点,当我们需要表示多对多的关系时, 这里我们就用到了图。 图是一种数据结构,其中结点可以具有零个或多个相邻元素。两个结点之间的连接称为边。 结点也可以称为顶点。如图: 简单来说,图就是由顶点的有穷非空集合和顶点之间的边组成的集合。通常表示为:G(V,E),其中,G 表示一个图,V 表示顶点的集合,E 表示边的集合。 然后我们说说图中的一些常见概念: 节点(Vertex):图中的基本元素,用于表示某个实体。 边(Edge):连接两个节点的线段,用于表示节点之间的关系。 度(Degree):
62 0
|
6月前
|
算法 Java C++
《经典图论算法》迪杰斯特拉算法(Dijkstra)
这个是求最短路径的迪杰斯特拉算法,另外我还写了50多种《经典图论算法》,每种都使用C++和Java两种语言实现,熟练掌握之后无论是参加蓝桥杯,信奥赛,还是其他比赛,或者是面试,都能轻松应对。
|
8月前
|
算法 Java C++
图论
图论 “【5月更文挑战第20天】”
57 3
|
8月前
|
机器学习/深度学习 人工智能 算法
【图论 单源最短路】100276. 最短路径中的边
【图论 单源最短路】100276. 最短路径中的边
|
8月前
|
机器学习/深度学习 存储 人工智能
[第五章]图论&&BFS
[第五章]图论&&BFS
52 0
|
8月前
|
存储 机器学习/深度学习 算法
图论基础:从数学原理到C/C++实现
图论基础:从数学原理到C/C++实现
231 0
|
8月前
|
算法 C++ NoSQL
|
机器学习/深度学习 运维 算法
【图论基础数据结构及其应用】
【图论基础数据结构及其应用】
|
算法 搜索推荐
从图到算法【图论】
柯尼斯堡七桥问题是图论中的著名问题。
|
算法 定位技术
图论的灵魂——带你走进迪杰斯特拉算法的世界
图论的灵魂——带你走进迪杰斯特拉算法的世界
图论的灵魂——带你走进迪杰斯特拉算法的世界

热门文章

最新文章