网络最短路径Dijkstra算法
最近在学习算法,看到有人写过的这样一个算法,我决定摘抄过来作为我的学习笔记:
<span style="font-size:18px;">/* * File: shortest.c * Description: 网络中两点最短路径 Dijkstra 算法 * Shortest Path Dijkstra Algorithm * Created: 2001/11/25 * Author: Justin Hou [mailto:justin_hou@hotmail.com] */ #include <stdio.h> #define true 1 #define false 0 #define I 9999 /* 无穷大 */ #define N 20 /* 城市顶点的数目 */ int cost[N][N] = { {0,3,I,I,I,1,I,I,I,I,I,I,I,I,I,I,I,I,I,I}, {3,0,5,I,I,I,6,I,I,I,I,I,I,I,I,I,I,I,I,I}, {I,5,0,4,I,I,I,1,I,I,I,I,I,I,I,I,I,I,I,I}, {I,I,4,0,2,I,I,I,6,I,I,I,I,I,I,I,I,I,I,I}, {I,I,I,2,0,I,I,I,I,7,I,I,I,I,I,I,I,I,I,I}, {1,I,I,I,I,0,1,I,I,I,2,I,I,I,I,I,I,I,I,I}, {I,6,I,I,I,1,0,6,I,I,I,7,I,I,I,I,I,I,I,I}, {I,I,1,I,I,I,6,0,2,I,I,I,3,I,I,I,I,I,I,I}, {I,I,I,6,I,I,I,2,0,8,I,I,I,4,I,I,I,I,I,I}, {I,I,I,I,7,I,I,I,8,0,I,I,I,I,5,I,I,I,I,I}, {I,I,I,I,I,2,I,I,I,I,0,4,I,I,I,3,I,I,I,I}, {I,I,I,I,I,I,7,I,I,I,4,0,3,I,I,I,4,I,I,I}, {I,I,I,I,I,I,I,3,I,I,I,3,0,3,I,I,I,5,I,I}, {I,I,I,I,I,I,I,I,4,I,I,I,3,0,7,I,I,I,2,I}, {I,I,I,I,I,I,I,I,I,5,I,I,I,7,0,I,I,I,I,3}, {I,I,I,I,I,I,I,I,I,I,3,I,I,I,I,0,5,I,I,I}, {I,I,I,I,I,I,I,I,I,I,I,4,I,I,I,5,0,8,I,I}, {I,I,I,I,I,I,I,I,I,I,I,I,5,I,I,I,8,0,6,I}, {I,I,I,I,I,I,I,I,I,I,I,I,I,2,I,I,I,6,0,4}, {I,I,I,I,I,I,I,I,I,I,I,I,I,I,3,I,I,I,4,0} }; int dist[N]; /* 存储当前最短路径长度 */ int v0 = 'A' - 65; /* 初始点是 A */ void main() { int final[N], i, v, w, min; /* 初始化最短路径长度数据,所有数据都不是最终数据 */ for (v = 0; v < N; v++) { final[v] = false; dist[v] = cost[v0][v]; } /* 首先选v0到v0的距离一定最短,最终数据 */ final[v0] = true; /* 寻找另外 N-1 个结点 */ for (i = 0; i < N-1; i++) { min = I; /* 初始最短长度无穷大 */ /* 寻找最短的边 */ for (w = 0; w < N; w++) { if (!final[w] && dist[w] < min) { min = dist[w]; v = w; } } final[v] = true; /* 加入新边 */ for (w = 0; w < N; w++) { /* 更新 dist[] 数据 */ if (!final[w] && dist[v] + cost[v][w] < dist[w]) { dist[w] = dist[v] + cost[v][w]; } } } for (i = 0; i < N; i++) { /* 显示到监视器 */ printf("%c->%c: %2d\t", v0 + 65, i + 65, dist[i]); } }</span>
运行结果:
网络最短路径Dijkstra算法的更多相关文章
- 有向网络(带权的有向图)的最短路径Dijkstra算法
什么是最短路径? 单源最短路径(所谓单源最短路径就是只指定一个顶点,最短路径是指其他顶点和这个顶点之间的路径的权值的最小值) 什么是最短路径问题? 给定一带权图,图中每条边的权值是非负的,代表着两顶点 ...
- 单源最短路径Dijkstra算法,多源最短路径Floyd算法
1.单源最短路径 (1)无权图的单源最短路径 /*无权单源最短路径*/ void UnWeighted(LGraph Graph, Vertex S) { std::queue<Vertex&g ...
- 最短路径-Dijkstra算法与Floyd算法
一.最短路径 ①在非网图中,最短路径是指两顶点之间经历的边数最少的路径. AE:1 ADE:2 ADCE:3 ABCE:3 ②在网图中,最短路径是指两顶点之间经历的边上权值之和最短的路径 ...
- 数据结构实验之图论七:驴友计划 ( 最短路径 Dijkstra 算法 )
数据结构实验之图论七:驴友计划 Time Limit: 1000 ms Memory Limit: 65536 KiB Submit Statistic Discuss Probl ...
- 最短路径——Dijkstra算法以及二叉堆优化(含证明)
一般最短路径算法习惯性的分为两种:单源最短路径算法和全顶点之间最短路径.前者是计算出从一个点出发,到达所有其余可到达顶点的距离.后者是计算出图中所有点之间的路径距离. 单源最短路径 Dijkstra算 ...
- Python数据结构与算法之图的最短路径(Dijkstra算法)完整实例
本文实例讲述了Python数据结构与算法之图的最短路径(Dijkstra算法).分享给大家供大家参考,具体如下: # coding:utf-8 # Dijkstra算法--通过边实现松弛 # 指定一个 ...
- 求两点之间最短路径-Dijkstra算法
Dijkstra算法 1.定义概览 Dijkstra(迪杰斯特拉)算法是典型的单源最短路径算法,用于计算一个节点到其他所有节点的最短路径.主要特点是以起始点为中心向外层层扩展,直到扩展到终点为止.D ...
- 单源最短路径——Dijkstra算法学习
每次都以为自己理解了Dijkstra这个算法,但是过没多久又忘记了,这应该是第4.5次重温这个算法了. 这次是看的胡鹏的<地理信息系统>,看完之后突然意识到用数学公式表示算法流程是如此的好 ...
- 最短路径(Dijkstra算法)
当用图结构来表示通信.交通等网络,权重代表距离或者成本,寻找最短路径就成为了一个重要的任务. 给定带权网络G=(V;E),源点s,对于其他所有顶点v,寻找s到v的最短路径,连接成一颗最短路径树.可以证 ...
随机推荐
- Dynamics CRM2015 页面导航栏顶部全局快速查找功能配置
在CRM2015中微软加入了新的快速查找功能,让你的数据查找更加方便,功能栏如下图所示,直接可以框中输入搜索项进行搜索. 但该功能是需要进行些配置,具体的配置在设置-管理-系统设置中,默认的就是红框中 ...
- 如何将Provisioning Profile安装到开发的Mac系统上
大熊猫猪·侯佩原创或翻译作品.欢迎转载,转载请注明出处. 如果觉得写的不好请多提意见,如果觉得不错请多多支持点赞.谢谢! hopy ;) 免责申明:本博客提供的所有翻译文章原稿均来自互联网,仅供学习交 ...
- 1060. Are They Equal (25)
题目如下: If a machine can save only 3 significant digits, the float numbers 12300 and 12358.9 are consi ...
- 【Unity Shaders】Transparency —— 使用alpha通道创建透明效果
本系列主要参考<Unity Shaders and Effects Cookbook>一书(感谢原书作者),同时会加上一点个人理解或拓展. 这里是本书所有的插图.这里是本书所需的代码和资源 ...
- 仿iphone快速导航悬浮球
用过iphone的朋友都知道,iPhone有个圆球辅助工具,它漂浮在你的手机屏幕(在任何APP之上),你可以将它移动到任何地方,它叫做AssistiveTouch,本篇模拟该软件实现一个小案例,主要是 ...
- Oracle EBS R12多组织(多OU)访问架构
Oracle EBS R12多组织访问架构 多组织架构实现了经营单位(OU)的数据安全性,在底层数据表中有一列ORG_ID来记录数据所属的经营单一,所有多OU的基表都是以"_ALL" ...
- 从JDK源码角度看并发锁的优化
在CLH锁核心思想的影响下,JDK并发包以CLH锁作为基础而设计,其中主要是考虑到CLH锁更容易实现取消与超时功能.比起原来的CLH锁已经做了很大的改造,主要从两方面进行了改造:节点的结构与节点等待机 ...
- noSQL数据库相关软件介绍(大数据存储时候,必须使用)
目前图数据库软件七种较为流行:Neo4J, Infinite Graph, DEX,InfoGrid, HyperGraphDB, Trinity, AllegroGraph(http://tech. ...
- pig运行方法:本地与云上
pig脚本 放在本地当前目录(键入pig命令时,所处的目录),然后用进入grunt,用run或者exec调用 1云运行: 键入pig进入grunt,用run命令运行当前目录脚本.(或者外部用pig - ...
- javascript之BOM浏览器对象模型引入
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/ ...