博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Dijkstra 算法
阅读量:7195 次
发布时间:2019-06-29

本文共 1248 字,大约阅读时间需要 4 分钟。

算法的核心思想:在尚未使用的顶点中,d[i]最小的顶点就是最短距离已经确定的顶点

解释:以图1-1为例,假设A,B,C已经被标记,则剩下的点可以认为经过A,B,C三点的松弛操作(看通过这个点作为中转站会不会使得其他点离起点更近)。

那么在被标记的顶点中,找出d[i]最小的顶点,就可以认为它就是最短距离已经确定的顶点。我们用反证法,假如它的值不是最短距离,那么你想A,B,C三点已经都对其余剩下所有的点进行了松弛操作,那么现在就不能再使其他点到起点的距离变得更短;那么就只能想办法通过其他点让它到起点的距离变短,然而由于不存在负边,不可能通过其他的点让它到起点的距离变得更短(不会在之后的更新中变小)。因此,就可以认为它就是最短距离已经确定的顶点。

自然而然我们就发现Dijkstra 算法不适合处理有负边的情况

 

 模板如下:

int cost[MAX_N][MAX_N]; //cost[u][v]表示边e(u,v)的权值(不存在时设为INF) int d[MAX_N]; //图上各点到顶点s的最短距离 int vis[MAX_N]; //已经使用过的图int n; //顶点数 memset(vis, 0, sizeof(vis));memset(d, 0x3f, sizeof(d));d[s] = 0;    while (1) {    int v = -1;    //从尚未使用过的顶点中选择一个距离最小的顶点     for (int i = 1; i <= n; i++)        if (vis[i]==0 && (v==-1||d[i]

仔细想想,其实我们还能进一步优化这个算法,需要优化的是数值的插入(更新)和取出最小值两个操作,因此使用就可以了。

优化后的模板入下:

struct edge {
int to, cost};typedef pair
P;int V;vector
G[MAX_V];int d[MAX_V];priority_queue
, greater

>que;fill(d, d+V, INF);d[s] = 0;que.push(P(0, s));while (!que.empty()) { P p = que.top(); que.pop(); int v = p.second; if (d[v]

d[v]+e.cost) { d[e.to] = d[v]+e.cost; que.push(P(d[e.to, e.to])); } }}

 

转载于:https://www.cnblogs.com/wizarderror/p/10902223.html

你可能感兴趣的文章
linux笔记:linux常用命令-关机重启命令
查看>>
想要提高网页转换率?试试这16个UI秘诀
查看>>
转)VCSA 6.5重启无法访问,报错“503 Service Unavailable”的解决方法
查看>>
Configuring and troubleshooting a Schema Provider
查看>>
Windows环境安装MySQL数据库
查看>>
javascript函数以及作用域简介
查看>>
Windows Phone 编程中页面间传值方法 - [WP开发]
查看>>
apollo实现c#与android消息推送(四)
查看>>
Spring 上下文操作工具类 ContextUtils
查看>>
程序员的智囊库系列之3--分布式文件系统(Distributed file systems)
查看>>
工具推荐|程序员必须知道的11款新型编程工具
查看>>
Python入门之基础语法
查看>>
poj 2714 Random Walk
查看>>
SQL Server中数据的存储
查看>>
jQuery 属性操作方法
查看>>
LeetCode——Longest Consecutive Sequence
查看>>
Activity转换为View和把图片转换为View
查看>>
參考mudo logging写的win下logging
查看>>
云数据库PolarDB(一)
查看>>
[数据结构] 迷宫问题(栈和队列,深搜和广搜)
查看>>