Dijkstra算法图文详解
2024-08-28 16:32:30
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;
}
最新文章
- 数据库中用varbinary存储二进制数据
- Day Six(Beta)
- solr-5.3部署到tomcat
- 我的linux桌面
- Hello 2016
- android studio 改变代码提示的方法
- linux增加用户并赋予权限/用户和用户组操作命令
- OGLplus 0.33.0 发布,OpenGL 的 C 封装库
- 大话设计模式(带目录完整版).pdf等
- hive UDAF源代码分析
- acdream暴力专场中的优美暴力
- curl向web服务器发送json数据
- 动态添加删除网卡 - 每天5分钟玩转 OpenStack(156)
- [原创]ssget过滤动态块的方式
- spring boot 整合 百度ueditor富文本
- python学习笔记之自定义函数的导入
- SQL Server中Text和varchar(max) 区别
- 学习笔记TF025:自编码器
- consul之:ACL配置使用
- ubuntu16.04搭建geodjango+postgresql+postgis的WebGIS框架(二))安装postgresql和postgis
热门文章
- (修改)oracle11g监听多台主机配置,用pl/sql连接操作多个数据库详解
- Eclipse Maven 编译错误 Dynamic Web Module 3.0 requires Java 1.6 or newer 解决方案
- Latex 多个参考文献的引用
- Ros学习——值得学习的package
- TinkerPop中的遍历:图的遍历步骤(3/3)
- Java泛型读书笔记 (一)
- mysql字段名与关键字冲突(near ";to";:syntax error)
- HeadFirst设计模式中的笔记
- Java连接Hbase异常
- [LeetCode] 92. Reverse Linked List II_Medium tag: Linked List