dijkstra最短路算法

来源:互联网 发布:淘宝网页编辑 编辑:程序博客网 时间:2024/05/22 11:32

Dijkstra算法

1.定义概览

Dijkstra(迪杰斯特拉)算法是典型的单源最短路径算法,用于计算一个节点到其他所有节点的最短路径。主要特点是以起始点为中心向外层层扩展,直到扩展到终点为止。Dijkstra算法是很有代表性的最短路径算法,在很多专业课程中都作为基本内容有详细的介绍,如数据结构,图论,运筹学等等。注意该算法要求图中不存在负权边。

问题描述:在无向图 G=(V,E) 中,假设每条边 E[i] 的长度为 w[i],找到由顶点 V0 到其余各点的最短路径。(单源最短路径)

 

2.算法描述

1)算法思想:设G=(V,E)是一个带权有向图,把图中顶点集合V分成两组,第一组为已求出最短路径的顶点集合(用S表示,初始时S中只有一个源点,以后每求得一条最短路径 , 就将加入到集合S中,直到全部顶点都加入到S中,算法就结束了),第二组为其余未确定最短路径的顶点集合(用U表示),按最短路径长度的递增次序依次把第二组的顶点加入S中。在加入的过程中,总保持从源点v到S中各顶点的最短路径长度不大于从源点v到U中任何顶点的最短路径长度。此外,每个顶点对应一个距离,S中的顶点的距离就是从v到此顶点的最短路径长度,U中的顶点的距离,是从v到此顶点只包括S中的顶点为中间顶点的当前最短路径长度。

2)算法步骤:

a.初始时,S只包含源点,即S={v},v的距离为0。U包含除v外的其他顶点,即:U={其余顶点},若v与U中顶点u有边,则<u,v>正常有权值,若u不是v的出边邻接点,则<u,v>权值为∞。

b.从U中选取一个距离v最小的顶点k,把k,加入S中(该选定的距离就是v到k的最短路径长度)。

c.以k为新考虑的中间点,修改U中各顶点的距离;若从源点v到顶点u的距离(经过顶点k)比原来距离(不经过顶点k)短,则修改顶点u的距离值,修改后的距离值的顶点k的距离加上边上的权。

d.重复步骤b和c直到所有顶点都包含在S中。

 

执行动画过程如下图

 

3.算法实例

先给出一个无向图

用Dijkstra算法找出以A为起点的单源最短路径步骤如下

 4.program:(不是上面这道题的代码)

#include<stdio.h>#include<string.h>#include<algorithm>using namespace std;int n[1005], vis[1005], dis[1005], Map[1005][1005];const int INF = 0x3f3f3f3f;int N, M, P, Q;void dijstar(int x){    memset(vis, 0, sizeof(vis));    vis[x] = 1;   //标记某个点是否被松弛过    for(int i = 1; i <= M; i++)        dis[i] = Map[x][i];   //初始化第一个点都别的各点距离    for(int i = 1; i <= M; i++) //遍历所有点求到每个点的距离    {        int min2 = INF;        int temp;        for(int j = 1; j <= M; j++) // 寻找下一个离当前点最近的的点            if(!vis[j] && dis[j] < min2)            {                min2 = dis[j];                temp = j;            }        if(min2 == INF)            break;        vis[temp] = 1; //标记该点已经被松弛过        for(int j = 1; j <= M; j++)            if(Map[temp][j] < INF && dis[j] > dis[temp] + Map[temp][j])            {                dis[j] = dis[temp] + Map[temp][j];            }    }}int main(){    int T;    scanf("%d", &T);    while(T--)    {        scanf("%d%d%d%d", &N, &M, &P, &Q);        for(int i = 1; i <= M; i++)            for(int j = 1; j <= M; j++)            {                if(i == j) Map[i][j] = 0;                else                    Map[i][j] = INF;            }        for(int i = 1; i <= N; i++)            scanf("%d", n+i);        for(int i = 0; i < P; i++)        {            int x, y, z;            scanf("%d%d%d", &x, &y, &z);            Map[x][y] = Map[y][x] = z;        }        int min1 = INF;        dijstar(Q);        for(int i = 1; i <= N; i++)        {            if(dis[n[i]] < min1)                min1 = dis[n[i]];        }        printf("%d\n", min1);    }    return 0;}



0 0
原创粉丝点击
热门问题 老师的惩罚 人脸识别 我在镇武司摸鱼那些年 重生之率土为王 我在大康的咸鱼生活 盘龙之生命进化 天生仙种 凡人之先天五行 春回大明朝 姑娘不必设防,我是瞎子 万一填写了奔跑吧诈骗信息该怎么办 深圳限行时段堵在路上怎么办 开车堵在路上到了限行时间怎么办 兄妹之间都不想照顾母亲我该怎么办 小孩扁体发炎睡觉呼吸声沉重怎么办 客所思pk3老驱动有杂音怎么办 手机打不开解压包密码怎么办 在香港专柜买东西柜员少给货怎么办 恶魔猎手第二神器任务没选择怎么办 电脑放久了开不了机怎么办 你在主持时说错话了怎么办 1、你在主持时说错话了怎么办? 领导让你替他参加重要会议怎么办 在备孕期老公照了片怎么办 和混混打架后被混混纠缠怎么办 开了一年的瑜伽馆想关掉会员怎么办 广东工厂宿舍里面床板有臭虫怎么办 胃癌手术后12天引流液多怎么办 八个月了胎儿头还在上面怎么办 喂奶一个月后奶头又裂开了怎么办 孩子吃奶吃的奶头裂开了怎么办 很想打坐久就是受不了腿疼怎么办 宝宝含乳一直纠正不过来怎么办 婴儿衘乳不正确只吸乳头怎么办 怀孕7个月了晚上睡不着怎么办 尚德学校学费交了一半退学怎么办 随着年龄的增长胸越来越来小怎么办 运动文胸里边的海绵垫会乱跑怎么办 带胸罩时在外面忽然扣子开了怎么办 我的脸一边大一边小怎么办 桶装水盖子吸在饮水机了怎么办? 孕37周大腿内侧被内裤磨烂怎么办 生存指南合成的时候闪退怎么办 王者荣耀队友用语音骂我怎么办? 轨道衡电子计量数据不对上怎么办 孕5个月胎儿发育慢怎么办 扎高马尾后面头发扎不上去怎么办 吃了不太新鲜的肉怎么办 军训腿疼的蹲不下去怎么办 面对对老师不尊重的学生该怎么办? 当学生犯了错老师应该怎么办?