Prim算法与Dijkstra算法的联系与区别
/* 图结构,邻接矩阵形式 */
ElemType nodes[n];
int edges[n][n];
prim_or_dijkstra( int index, bool usePrim ) /* 起点 */
{
int dist[n] = { INF }; /* 从起点开始,到其他所有边的距离 */
int distIndex[n] = { - };
int visited[n] = { };
int selected = index; /*选中的点 */
/* 初始化起点的可达边距离 */
for ( i = ; i < nodes.length; i++ )
/* edges[起点][终点]=权重(不是INF就有边),穷举 */
{
if ( visited[i] )
break;
visited[i] = true;
if ( edges[selected][i] != INF )
{
dist[i] = edges[selected][i]; /* index到可达边的距离 */
}
}
for ( k = ; k < nodes.length - ; k++ ) /* n-1次循环取点 */
{
visited[selected] = true;
int min = INF;
int sel = -;
for ( i = ; i < nodes.length; i++ )
/* edges[起点][终点]=权重(不是INF就有边),穷举 */
{
if ( visited[i] )
break; /* 属于同一集合,不必考虑 */
if ( edges[selected][i] != INF )
{
if ( min > dist[i] )
{
min = dist[i]; sel = i;
}
/* min=已经被选中的点的集合到其他单独的点的最短距离 */
/* sel=相应的点 */
}
}
distIndex[sel] = selected; /* sel->selected映射,存放边 */
/* 一个sel只对应一个selected, */
/* 一个selected对应多个sel */
/* 第一次distIndex v2->v1 */
selected = sel; /*选中的点要更新 */
/* 此时 */
/* prim中令 dist[selected]=0 */
/* dijkstra不添加代码 */
if ( usePrim )
{
dist[selected] = ;
}
for ( i = ; i < nodes.length; i++ ) /* selected->i,更新其他边 */
/* 由于selected已经是集合的一部分, */
/* selected的可达边的距离属于集合的可达边的距离 */
{
/* 在所有的集合的可达边(不包含集合自身)的距离中取较小值 */
/*下面是两种方法相同的部分 */
if ( !visited[i]
&& dist[i] > dist[selected] + edges[selected][i] )
{
dist[i] = dist[selected] + edges[selected][i]
}
}
}
联系:
两者在连边时,用的是同一种贪心策略,即对于将扩展的集合总是在非扩展的点中找一条最短的边入集合,并用新入集合的点修改剩下点的到集合的最短路。
共同点:都有visited标记数组,dist数组,min,distIndex数组
注意:网上大多数教程中,prim算法是没有visited数组的,它用令dist[]=0来简化,而在这里,两种方法都用了visited数组,减少了差异性
区别:
在于dist的修改和意义
dijkstra仅仅就多了一个dist[selected],用做累积距离
而prim中由于dist[selected]=0,故可消去dist[selected]
prim
if(!visited[i] && dist[i] > edges[selected][i])
{dist[i] = edges[selected][i];}
//解释:prim中集合内部的边看做短路,可忽略,长度为0
dijkstra
if(!visited[i]
&& dist[i] > dist[selected]+ edges[selected][i])
{dist[i] = dist[selected]+ edges[selected][i]}
//解释:dijkstra中集合内部的边不可忽略,长度存在
Prim算法与Dijkstra算法的联系与区别的更多相关文章
- 数据结构与算法系列研究七——图、prim算法、dijkstra算法
图.prim算法.dijkstra算法 1. 图的定义 图(Graph)可以简单表示为G=<V, E>,其中V称为顶点(vertex)集合,E称为边(edge)集合.图论中的图(graph ...
- Prim算法和Dijkstra算法的异同
Prim算法和Dijkstra算法的异同 之前一直觉得Prim和Dijkstra很相似,但是没有仔细对比: 今天看了下,主要有以下几点: 1: Prim是计算最小生成树的算法,比如为N个村庄修路,怎么 ...
- 算法设计(动态规划应用实验报告)实现基于贪婪技术思想的Prim算法、Dijkstra算法
一.名称 动态规划法应用 二.目的 1.贪婪技术的基本思想: 2.学会运用贪婪技术解决实际设计应用中碰到的问题. 三.要求 1.实现基于贪婪技术思想的Prim算法: 2.实现基于贪婪技术思想的Dijk ...
- 最短路径算法(Dijkstra算法、Floyd-Warshall算法)
最短路径算法具体的形式包括: 确定起点的最短路径问题:即已知起始结点,求最短路径的问题.适合使用Dijkstra算法. 确定终点的最短路径问题:即已知终结结点,求最短路径的问题.在无向图中,该问题与确 ...
- Prim算法、Kruskal算法、Dijkstra算法
无向加权图 1.生成树(minimum spanning trees) 图的生成树是它一棵含有所有顶点的无环联通子图 最小生成树:生成树中权值和最小的(所有边的权值之和) Prim算法.Kruskal ...
- 【最短路算法】Dijkstra+heap和SPFA的区别
单源最短路问题(SSSP)常用的算法有Dijkstra,Bellman-Ford,这两个算法进行优化,就有了Dijkstra+heap.SPFA(Shortest Path Faster Algori ...
- 最短路径算法之Dijkstra算法(java实现)
前言 Dijkstra算法是最短路径算法中为人熟知的一种,是单起点全路径算法.该算法被称为是“贪心算法”的成功典范.本文接下来将尝试以最通俗的语言来介绍这个伟大的算法,并赋予java实现代码. 一.知 ...
- 图中最短路径算法(Dijkstra算法)(转)
1.Dijkstra 1) 适用条件&范围: a) 单源最短路径(从源点s到其它所有顶点v); b) 有向图&无向图(无向图可以看作(u,v),(v,u)同属于边集E ...
- 最短路算法之Dijkstra算法通俗解释
Dijkstra算法 说明:求解从起点到任意点的最短距离,注意该算法应用于没有负边的图. 来,看图. 用邻接矩阵表示 int[][] m = { {0, 0, 0, 0, 0, 0}, {0, 0, ...
- 最短路经算法简介(Dijkstra算法,A*算法,D*算法)
据 Drew 所知最短路经算法现在重要的应用有计算机网络路由算法,机器人探路,交通路线导航,人工智能,游戏设计等等.美国火星探测器核心的寻路算法就是采用的D*(D Star)算法. 最短路经计算分静态 ...
随机推荐
- c# 基础之数组(包含三维数组)
public enum ChessType { White = , None=, Black=, } class Program { static void Main(string[] args) { ...
- Servlet异常及其生命周期
Servlet 异常 在javax.servlet包中定义了两个异常类 ServletException类 ServletException类定义了一个通用的异常,可以被init().service( ...
- python_way day11 自定义线程池
python_way day11 线程池 为什么需要线程池 线程多一些固然好,但是过多的线程反倒影响系统的负荷,所以我们就需要创建合适多的线程,哪我们把线程放到哪里?这时就放到线程池中. 线程池中存放 ...
- GBASE结构理解
GBASE数据库 8a 8a Cluster 8t 8m BI 8d 8 分析型数据库 分布式并行数据库集群 高端事务性数据库 高速内存数据库 可视商业智能 大型目录服务体系 硬加密安全数据库 数据分 ...
- STORM_0005_第一个非常简单的storm topology的提交运行
配置好storm之后就可以开始在eclipse里面写topology了. 下面是我在网上搜到的一个简单的例子,我按照自己的理解注释了一下. 第一步,创建mvn工程 这是pom.xml文件 <pr ...
- JPG 批量压缩、 PNG32、PNG24转PNG 透明批量压缩工具 【JPNG】 支持多级目录
说在最前,压缩不一定是最好的,仅仅是为了方便自己工作需要.主要是手机端图片 算法说明:JPG压缩使用的是 adobe 的 JPGEncoder+ AIR的JPEGEncoderOptions (注 ...
- LTE Module User Documentation(翻译2)——配置LTE MAC 调度器
LTE用户文档 (如有不当的地方,欢迎指正!) 5 配置 LTE MAC 调度器 这里有几种 LTE MAC 调度器用户可以选择.使用下面的代码定义调度器的类型: Ptr<LteHelper ...
- iOS - UIKit
1.UIKit 框架基本结构 1)控件 屏幕上的所有 UI 元素都叫做控件(也有叫做视图.组件),比如按钮(UIButton).文本(UILabel)都是控件. 为了便于开发者打造各式各样的优秀 Ap ...
- mysql 锁的粒度
1.锁的类型分为读锁和写锁,这个很好区分.可以这样认为:如果有增删改,就是写锁.如果是查询,就是读锁.2.锁的粒度也就是锁的范围,分为行锁和表锁.锁的范围和多个因素有关,包括事务隔离级别.是否使用索引 ...
- Android linearlayout常用布局
用linearlayout完成这样的布局效果,这样的布局还是比较常用的,具体的xml代码如下: <LinearLayout xmlns:android="http://schemas. ...