这个算法适用于求单源最短路径,从一点出发,到其余个点的最短路径。

算法要点:

1、用二维数组存放点到点的距离-----不能相互到达的点用MAX代替距离

2、用dis数组存放源点到任意其他一点的距离----dis【5】表示源点到5点的距离为dis【5】中的值

3、用book数组记录已经确定最小dis的点

4、用index和indexNumber存放估计值的点

5、从源点到这个点如果比中间加上估计值的点还要长,就松弛

算法模型:

for(循环N次)

for(循环找到估计值点)

估计值点是现在的dis中距离源点最近的点。

book数组记录已经走过这个估计值点

for(循环N次)

if(dis【循环值】> dis【估计值】+maps【估计值】【循环值】)//从源点到这个点如果比中间加上估计值的点还要长,就松弛

dis【循环值】=  dis【估计值】+maps【估计值】【循环值】

#include<cstdio>
#include<cstdlib>
#include<iostream> using namespace std;
/*Dijkstra*/ int dis[];
int book[];
int maps[][];
const int MAX = ;//定义一个最大值,距离不会超过这个 int main()
{
int i,j,q;//循环变量
int n,m;
int x,y,z;
int index,indexNumber;//离当前点最近的点的坐标和坐标
cin>>n>>m;//输入N*N的图,和M条边对应的值 for (i = ; i <= n; i++)//初始化dis距离
dis[i] = MAX; for (i = ; i <= n; i++)//初始化maps里面的所有距离
for (j = ; j <= n; j++)
if(i != j)
maps[i][j] = MAX;
else
maps[i][j] = ; for (i = ; i <= m; i++)
{
cin>>x>>y>>z;//输入x到y的距离为z
maps[x][y] = z;
if(x==)
dis[y] = z;//如果是x=1,那么就是1点到别的点的距离,用dis保存
} dis[] = ;//自己到自己肯定是0
book[] = ;//默认从1点开始找
for (q = ; q <= n; q++)
{
index=;
indexNumber = MAX;
for (j = ; j <= n; j++)
{
if(book[j] == )
{
if(dis[j] < indexNumber)
{
indexNumber = dis[j];
index = j;
}
}
} book[index] = ;//证明这个点已经来过
for (i = ; i <= n; i++)//循环N次
{
if(book[i] == && maps[index][i] != MAX)//松弛过的点和不可能通过松弛的点先扔掉
{
if(dis[i] > dis[index] + maps[index][i])//从1点到这个点如果比中间加上index点还要长,就松弛
{
dis[i] = dis[index] + maps[index][i];
}
} }
} for (i = ; i <= n; i++)
{
cout<<dis[i]<<" ";
}
cout<<endl;
} /*
测试数据
6 9
1 2 1
1 3 12
2 3 9
2 4 3
3 5 5
4 3 4
4 5 13
4 6 15
5 6 4
R:0 1 8 4 13 17
*/

这个算法还能根据实际情况去优化,时间复杂度还能减少,优化下次再继续研究。

需要注意的是,这个算法利用贪心的思想,尽可能找到最短中的最短,已经最短的了,就已经是最短的了,就不变了,也就是为什么会有book数组去标识这个点是不是已经是一个确定的值,已经是最短的了,但是这样的话就不能处理负数距离的情况,所以还是有一定的使用范围的,使用时需要注意。

最短路径算法专题2----Dijkstra的更多相关文章

  1. 最短路径算法之二——Dijkstra算法

    Dijkstra算法 Dijkstra算法主要特点是以起始点为中心向外层层扩展,直到扩展到终点为止. 注意该算法要求图中不存在负权边. 首先我们来定义一个二维数组Edge[MAXN][MAXN]来存储 ...

  2. 最短路径算法专题3----Bellman-Ford

    这个算法也是求单源最短路径用的,但是这个算法可以解决Dijkstra不能解决的负权边问题. 算法要点: 1.用dis存放源点到任意一点的距离. 2.用三个数组存放输入的点到点以及点到点的距离,x[i] ...

  3. 几个最短路径算法Floyd、Dijkstra、Bellman-Ford、SPFA的比较

        几大最短路径算法比较 转自:http://blog.csdn.net/v_july_v/article/details/6181485 几个最短路径算法的比较: Floyd        求多 ...

  4. 几个最短路径算法Floyd、Dijkstra、Bellman-Ford、SPFA的比较(转)

    几大最短路径算法比较 几个最短路径算法的比较:Floyd        求多源.无负权边(此处错误?应该可以有负权边)的最短路.用矩阵记录图.时效性较差,时间复杂度O(V^3).       Floy ...

  5. 最短路径算法总结(floyd,dijkstra,bellman-ford)

    继续复习数据结构和算法,总结一下求解最短路径的一些算法. 弗洛伊德(floyd)算法 弗洛伊德算法是最容易理解的最短路径算法,可以求图中任意两点间的最短距离,但时间复杂度高达\(O(n^3)\),主要 ...

  6. 单元最短路径算法模板汇总(Dijkstra, BF,SPFA),附链式前向星模板

    一:dijkstra算法时间复杂度,用优先级队列优化的话,O((M+N)logN)求单源最短路径,要求所有边的权值非负.若图中出现权值为负的边,Dijkstra算法就会失效,求出的最短路径就可能是错的 ...

  7. 最短路径算法——Dijkstra,Bellman-Ford,Floyd-Warshall,Johnson

    根据DSqiu的blog整理出来 :http://dsqiu.iteye.com/blog/1689163 PS:模板是自己写的,如有错误欢迎指出~ 本文内容框架: §1 Dijkstra算法 §2 ...

  8. Dijkstra 单源最短路径算法

    Dijkstra 算法是一种用于计算带权有向图中单源最短路径(SSSP:Single-Source Shortest Path)的算法,由计算机科学家 Edsger Dijkstra 于 1956 年 ...

  9. 几大最短路径算法比较(Floyd & Dijkstra & Bellman-Ford & SPFA)

    几个最短路径算法的比较:Floyd 求多源.无负权边(此处错误?应该可以有负权边)的最短路.用矩阵记录图.时效性较差,时间复杂度O(V^3).       Floyd-Warshall算法(Floyd ...

随机推荐

  1. 2015 Multi-University Training Contest 10

    1001 CRB and Apple 1002 CRB and Candies 1003 CRB and Farm 1004 CRB and Graph 1005 CRB and His Birthd ...

  2. 创建mysql数据表成功

    create table picindex(id int NOT NULL AUTO_INCREMENT,userName varchar(255) NOT NULL,cur int(11) NOT ...

  3. Hibernate查询、连接池、二级缓存

    Hibernate第三天: 1. 对象状态 2. session缓存 3. lazy懒加载 4. 映射 一对一对映射 组件/继承映射 目标: 一.hibernate查询 二.hibernate对连接池 ...

  4. NDK常见问题

    1. 忽略编译警告为错误 APP_CPPFLAGS += -Wno-error=format-security 2. android studio 手动编译 __android_log_print 错 ...

  5. 数组实现UITabview的cell设置

  6. android 属性动画

    一直再追郭霖的博客和imooc上的一些新的视频,最近有讲到属性动画. 以下内容为博客学习以及imooc上视频资料的学习笔记: 在3.0之前比较常见的动画为tween动画和frame动画: tween动 ...

  7. hdu_4823_Energy Conversion

    题目连接:http://acm.hdu.edu.cn/showproblem.php?pid=4823 题意:中文题,很清楚,要注意的是乘起来会爆int 题解: #include<cstdio& ...

  8. 7.在第4题中Hello.class所在路径下, 输入命令:java Hello.class,会出现什么结果,为什么?

    java Hello已经是加载类了

  9. FUSE and File System

    FUSE: File system in USErspace. So what is a file system? A file system maps file paths to file cont ...

  10. cornerstone 怎么使用

    Cornerstone的逻辑很清晰,界面打开后,左边栏上下分开,上面是working copies的列表,下面是REPOSITORIES的列表.常见的功能基本上跟windows一样,在上下文中可以得到 ...