Dijkstra算法

Dijkstra算法算是贪心思想实现的,首先把起点到所有点的距离存下来找个最短的,然后松弛一次再找出最短的,所谓的松弛操作就是,遍历一遍看通过刚刚找到的距离最短的点作为中转站会不会更近,如果更近了就更新距离,这样把所有的点找遍之后就存下了起点到其他所有点的最短距离。

问题引入:

指定一个点(源点)到其余各个顶点的最短路径,也叫做“单源最短路径”。例如求下图中的1号顶点到2、3、4、5、6号顶点的最短路径。

 

下面我们来模拟一下:

这就是Dijkstra算法的基本思路:

接下来是代码:

已经把几个过程都封装成了基本模块:

#include<cstdio>
#include<cstring>
#include<algorithm>
#include<iostream>
#define Inf 0x3f3f3f3f using namespace std; int map[1005][1005]; int vis[1005],dis[1005];
int n,m;//n个点,m条边 void Init ()
{
memset(map,Inf,sizeof(map));
for(int i=1;i<=n;i++)
{
map[i][i]=0;
}
} void Getmap()
{
int u,v,w;
for(int t=1;t<=m;t++)
{
scanf("%d%d%d",&u,&v,&w);
if(map[u][v]>w)
{
map[u][v]=w;
map[v][u]=w;
}
} } void Dijkstra(int u)
{
memset(vis,0,sizeof(vis));
for(int t=1;t<=n;t++)
{
dis[t]=map[u][t];
}
vis[u]=1;
for(int t=1;t<n;t++)
{
int minn=Inf,temp;
for(int i=1;i<=n;i++)
{
if(!vis[i]&&dis[i]<minn)
{
minn=dis[i];
temp=i;
}
}
vis[temp]=1;
for(int i=1;i<=n;i++)
{
if(map[temp][i]+dis[temp]<dis[i])
{
dis[i]=map[temp][i]+dis[temp];
}
}
} } int main()
{ scanf("%d%d",&m,&n);
Init();
Getmap();
Dijkstra(n);
printf("%d\n",dis[1]); return 0;
}

最新文章

  1. 数据库中用varbinary存储二进制数据
  2. Day Six(Beta)
  3. solr-5.3部署到tomcat
  4. 我的linux桌面
  5. Hello 2016
  6. android studio 改变代码提示的方法
  7. linux增加用户并赋予权限/用户和用户组操作命令
  8. OGLplus 0.33.0 发布,OpenGL 的 C 封装库
  9. 大话设计模式(带目录完整版).pdf等
  10. hive UDAF源代码分析
  11. acdream暴力专场中的优美暴力
  12. curl向web服务器发送json数据
  13. 动态添加删除网卡 - 每天5分钟玩转 OpenStack(156)
  14. [原创]ssget过滤动态块的方式
  15. spring boot 整合 百度ueditor富文本
  16. python学习笔记之自定义函数的导入
  17. SQL Server中Text和varchar(max) 区别
  18. 学习笔记TF025:自编码器
  19. consul之:ACL配置使用
  20. ubuntu16.04搭建geodjango+postgresql+postgis的WebGIS框架(二))安装postgresql和postgis

热门文章

  1. (修改)oracle11g监听多台主机配置,用pl/sql连接操作多个数据库详解
  2. Eclipse Maven 编译错误 Dynamic Web Module 3.0 requires Java 1.6 or newer 解决方案
  3. Latex 多个参考文献的引用
  4. Ros学习——值得学习的package
  5. TinkerPop中的遍历:图的遍历步骤(3/3)
  6. Java泛型读书笔记 (一)
  7. mysql字段名与关键字冲突(near &quot;to&quot;:syntax error)
  8. HeadFirst设计模式中的笔记
  9. Java连接Hbase异常
  10. [LeetCode] 92. Reverse Linked List II_Medium tag: Linked List