最短路算法之 Dijkstra算法
Dijkstra算法
Dijkstra算法是典型最短路算法,用于计算一个节点到其它全部节点的最短路径。
主要特点是以起始点为中心向外层层扩展,直到扩展到终点为止。Dijkstra算法能得出最短路径的最优解。但因为它遍历计算的节点非常多,所以效率低。
Dijkstra算法是用来求随意两个顶点之间的最短路径。在该算法中。我们用邻接矩阵来存储图。在该程序中设置一个二维数组来存储随意两个顶点之间的边的权值。能够将随意一个图的信息通过键盘输入,让后在输入要查找的两个顶点。程序能够自己主动求出这两个顶点之间的最短路径。
算法思想
s为源。Map[u,v] 为点u 和v 之间的边的长度,结果保存在 dis[];
初始化:源的距离dis[s]设为0。其它的点距离设为无穷大,同一时候把全部的点状态设为没有扩展过。
循环n-1次:
1. 利用标记变量数组 在没有扩展过的点中取一距离最小的点u。并将其状态设为已扩展。
2. 对于每一个与u相邻的点v,假设dis[u] + Map[u,v] < dis[v]。那么把dist[v]更新成更短的距离dis[u] + Map[u,v] 。
此时到点v的最短路径上,前一个节点即为u。
结束:此时对于随意的u,dist[u]就是s到u的距离。
附 Hdu 2544 最短路
做题思想
建立一个Map的二维数组 里面的初始值改为一个INF(大数) 把从A到B 的路径长度储存进去
建立一个Dis 的数组 储存Map[ s ][ 0 →n ]里的数据 循环N-1次 每次标记一个dis中最小的标号 并用
if(!flag[i] && dis[i]>dis[t] + Map[t][i]) 该标号更新Dis 数组
更新过后 dis[ x ] 即为源点S的到x 的最短距离
代码
#include<stdio.h> // Dijkstra 算法
#include<iostream>
#include<string.h>
#define INF 10000000
using namespace std;
int Map[101][101],dis[110];
int n ,m;
void Dijkstra()
{
int i,j,D = 0;
bool flag[110];
memset(flag,0,sizeof(flag)); //标记数组
for(i=1; i<=n; i++)
dis[i]=Map[1][i]; //与1处的距离 每个i代表自身与1的距离
for(i=1; i<n; i++) //每次循环标记一个点 一共标记n-1个点
{
int temp = INF;
for(j=1; j<=n; j++) //找出dis数组中的最小的那个值 位置用D记录下来
if(!flag[j]&&dis[j]<temp)
{
temp = dis[j];
D = j;
}
flag[D] = 1; //把该点标记
for(j=1; j<=n; j++) //更新dis数组 以D
{
if(!flag[j]&&dis[j] > Map[D][j]+dis[D])
dis[j] = Map[D][j]+dis[D];
}
}
}
int main()
{
int i,j,x,y,z;
while(scanf("%d %d",&n,&m)!=EOF&&(m||n))
{
for(i=0; i<101; i++) { //地图清空初始化为一个大数
for(j=0; j<101; j++)
Map[i][j] = INF;
Map[i][i]=0;
}
for(i=1; i<=m; i++)
{
cin >> x >> y >> z; //输入
if(Map[x][y] > z) //假设再次输入的 比之前的小,覆盖
Map[x][y]=Map[y][x] = z;
}
Dijkstra();
printf("%d\n",dis[n]); //所有循环过后,dis【n】的值即为从1到n 的距离;
}
return 0;
}
附:
ACM假期集训感悟:
一转眼半个月过去了,上午听师哥讲算法。看书;下午刷题,总结;
别人都说我们程序员苦,累;另一个外号 “屌丝程序员”。
可我并不这么觉得,每天学习算法锻炼思维,刷题提高代码能力和逻辑思维
在ACM训练中,最开心的时候就是花老长时间去改错。WA一遍又一遍,最终该出了最后一个BUG ,AC!
心情就无比的舒畅,看窗外的树叶是那样的翠绿,天是那样的蔚蓝。
在大学生活中能过的如此充实。有动力。有目标,朝着目标一步一步的走去。 是多么幸福的一件事
在这里。送出我的一句话:
整个世界填满不了十八岁男孩子的雄心和梦。
最短路算法之 Dijkstra算法的更多相关文章
- 【hdu 2544最短路】【Dijkstra算法模板题】
Dijkstra算法 分析 Dijkstra算法适用于边权为正的情况.它可用于计算正权图上的单源最短路( Single-Source Shortest Paths, SSSP) , 即从单个源点出发, ...
- 最短路径算法(Dijkstra算法、Floyd-Warshall算法)
最短路径算法具体的形式包括: 确定起点的最短路径问题:即已知起始结点,求最短路径的问题.适合使用Dijkstra算法. 确定终点的最短路径问题:即已知终结结点,求最短路径的问题.在无向图中,该问题与确 ...
- 数据结构与算法系列研究七——图、prim算法、dijkstra算法
图.prim算法.dijkstra算法 1. 图的定义 图(Graph)可以简单表示为G=<V, E>,其中V称为顶点(vertex)集合,E称为边(edge)集合.图论中的图(graph ...
- 算法设计(动态规划应用实验报告)实现基于贪婪技术思想的Prim算法、Dijkstra算法
一.名称 动态规划法应用 二.目的 1.贪婪技术的基本思想: 2.学会运用贪婪技术解决实际设计应用中碰到的问题. 三.要求 1.实现基于贪婪技术思想的Prim算法: 2.实现基于贪婪技术思想的Dijk ...
- 最短路算法之Dijkstra算法通俗解释
Dijkstra算法 说明:求解从起点到任意点的最短距离,注意该算法应用于没有负边的图. 来,看图. 用邻接矩阵表示 int[][] m = { {0, 0, 0, 0, 0, 0}, {0, 0, ...
- 最短路径算法之Dijkstra算法(java实现)
前言 Dijkstra算法是最短路径算法中为人熟知的一种,是单起点全路径算法.该算法被称为是“贪心算法”的成功典范.本文接下来将尝试以最通俗的语言来介绍这个伟大的算法,并赋予java实现代码. 一.知 ...
- 最短路经算法简介(Dijkstra算法,A*算法,D*算法)
据 Drew 所知最短路经算法现在重要的应用有计算机网络路由算法,机器人探路,交通路线导航,人工智能,游戏设计等等.美国火星探测器核心的寻路算法就是采用的D*(D Star)算法. 最短路经计算分静态 ...
- 非负权值有向图上的单源最短路径算法之Dijkstra算法
问题的提法是:给定一个没有负权值的有向图和其中一个点src作为源点(source),求从点src到其余个点的最短路径及路径长度.求解该问题的算法一般为Dijkstra算法. 假设图顶点个数为n,则针对 ...
- 【算法】Dijkstra算法(单源最短路径问题)(路径还原) 邻接矩阵和邻接表实现
Dijkstra算法可使用的前提:不存在负圈. 负圈:负圈又称负环,就是说一个全部由负权的边组成的环,这样的话不存在最短路,因为每在环中转一圈路径总长就会边小. 算法描述: 1.找到最短距离已确定的顶 ...
随机推荐
- docker常用命令整理
Docker常见用法整理 Docker 使用客户端-服务器 (C/S) 架构模式,使用远程API来管理和创建Docker容器. Docker 容器通过 Docker 镜像来创建.容器与镜像的关系类似于 ...
- DWR搭建以及使用教程
DWR搭建以及使用教程 DWR(Direct Web Remoting)是一个Ajax的开源框架,用于改善web页面与Java类交互的远程服务器端的交互体验,可以帮助开发人员开发包含AJAX技术的 ...
- 【bzoj4448】[Scoi2015]情报传递 主席树
题目描述 奈特公司是一个巨大的情报公司,它有着庞大的情报网络.情报网络中共有n名情报员.每名情报员口J-能有若T名(可能没有)下线,除1名大头日外其余n-1名情报员有且仅有1名上线.奈特公司纪律森严, ...
- 多啦A梦的制作
小叮当简单颜色单一,操作起来也很容易上手.接下来的一个实例就是用css画出一个多啦A梦,首先将其分为头部,和身体.然后,再根据身体各部分细节进行进一步的具体刻画. 由于最近一直在学习JavaWeb方面 ...
- div中div水平垂直居中
方法-1 img { vertical-align: middle; } div:before { content: ""; display: inline-block; widt ...
- 洛谷P1965 转圈游戏 [NOIP2013]
题目描述 n 个小伙伴(编号从 0 到 n-1)围坐一圈玩游戏.按照顺时针方向给 n 个位置编号,从0 到 n-1.最初,第 0 号小伙伴在第 0 号位置,第 1 号小伙伴在第 1 号位置,……,依此 ...
- 【ZOJ4060】 Flippy Sequence(规律)
题意:给定两个长度为n的01序列A和B,要求分别从两个序列中取两段将段中数字取反,使得A和B完全相同,求方案数 n<=1e6,sum(n)<=1e7 思路:现场8Y…… 将A和B异或之后问 ...
- BZOJ【1639】: [Usaco2007 Mar]Monthly Expense 月度开支
1639: [Usaco2007 Mar]Monthly Expense 月度开支 Time Limit: 5 Sec Memory Limit: 64 MBSubmit: 700 Solved: ...
- C#获取二维数组的行数和列数及其多维。。。
原文发布时间为:2008-11-26 -- 来源于本人的百度文章 [由搬家工具导入] 有一个二维数组sz[,] 怎样获取sz 的行数和列数呢? sz.GetLength(0) 返回第一维的长度(即行数 ...
- java中的序列化与反序列化,还包括将多个对象序列化到一个文件中
package Serialize; /** * Created by hu on 2015/11/7. */ //实现序列化必须实现的接口,这就是一个空接口,起到标识的作用 import java. ...