最短路径问题(dj和floyd算法)

2024-03-10 10:18

本文主要是介绍最短路径问题(dj和floyd算法),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

1. 首先是dj算法,dj算法的思想是从开始结点开始,每次找到距离开始结点距离最近的结点newP,加入到集合K中,表示已经访问过,然后遍历newP的直接相邻的结点,如果从newP结点开始到直接相邻的结点 i 的距离Dis[newP]+c < Dis[i],那么就更新Dis[i],扫描完成所有newP的邻接结点,然后遍历所有的结点,找到未访问过的并且Dis[i]最小的结点 j ,设为新的 newP ,重复上述步骤,直到所有的结点都完成了访问。

设置一个Dis[i]矩阵,表示从1到该结点的距离,Dis[1] = 0, 开始时其它结点的Dis[1] = -1.从1开始进行循环。

如果要打印最短路径,可以设置一个vector<int> pre[N], 每个结点 i ,将在更新Dis[i]时,更新 pre[i].push_back(newP), 通过newP到达 i 是当前从1到达i 的最短路径的上一个结点,这样从后向前打印即可。

看下面的这个例子:

从1出发,找到最短的邻接点 3,访问;从 3 开始遍历 3 的邻接点, 更新5的Dis[5] = 7, 从未访问的结点2,4,5中找到最近的结点2,访问,然后是4访问,遍历4的邻接点,Dis[5]更新为6,最后访问5;完成;

问题是:给出N个地点,M个直接路径,直接路径包括两端地点和它们直接长度,找出1到N号地点的最短路径:

代码为:

#include<cstdio>
#include<vector>
#include<math.h>
#include<algorithm>
using namespace std;
#define N 101
struct E{int next;int c;
};
vector<E> edge[N];//edge[i]中的与元素是一个个的E类型,包含了直接相连号和边权
bool mark[N];//表示该结点是否已经加入到最短路径已知集合中
int Dis[N];//从开始结点到任意结点的最短路径长度度int main()
{int n,m;//n个地点,m个直接相连路径,求从1到n的最短路径while(scanf("%d%d", &n, &m) != EOF){if(n == 0 && m == 0)break;for(int i = 1; i <= n; i++)edge[i].clear();while(m--){int a,b,cost;scanf("%d%d%d", &a, &b, &cost);E temp;temp.next = b;temp.c = cost;edge[a].push_back(temp);temp.next = a;edge[b].push_back(temp);//无向边,所以两个点的邻接链表都要增加}for(int i = 1; i <= n; i++){Dis[i] = -1;mark[i] = false;}Dis[1] = 0;mark[1] = true;int newP = 1;//表示是上一个加入到最短路径的点for(int i = 1; i < n; i++)//循环n-1次,将所有的点都加入到集合中{for(int j = 0; j < edge[newP].size(); j++){int t = edge[newP][j].next;int ct = edge[newP][j].c;if(mark[t] == true)continue;if(Dis[t] == -1 || Dis[t] > Dis[newP] + ct)Dis[t] = Dis[newP] + ct;}int min = 100000000;for(int k = 1; k <= n; k++){if(mark[k] == true)continue;if(Dis[k] == -1)continue;if(min > Dis[k]){min = Dis[k];newP = k;}}mark[newP] = true;}printf("%d\n", Dis[n]);}return 0;
}

运行结果,最后一个例子是上面的图:

2. floyd算法求最短路径,这种算法要求事先得到所有直接相连结点间的距离,然后依次判断i,j之间是否存在一个中间结点,使得

ans[i][j] > ans[i][k] + ans[k][j]从而得到新的ans[i][j]的值,要对这个中间结点进行所有结点的遍历,不可达的要跳过,对所有ans[i][j]进行遍历n次,就可以得到所有结点间的最短距离,包括i, j之间包含多个中间结点的情况,不用深入研究,记住即可。注意设定ans[i][i] = 0,所以 ans[i][j] == ans[i][i] + ans[i][j],不会进行更新。

代码为:

#include<cstdio>
#include<iostream>
using namespace std;int ans[101][101]; //初始值为邻接矩阵,只有直接相邻的结点的距离才有意义,否则为-1
int main()
{int n, m;while(scanf("%d%d", &n, &m) != EOF){if(n == 0 && m == 0)break;for(int i = 1; i <= n; i++){for(int j = 1; j <= n; j++){ans[i][j] = -1;}ans[i][i] = 0; //自己到自己的路径长度设为0}while(m--){int a, b, c;scanf("%d%d%d", &a, &b, &c);ans[a][b] = ans[b][a] = c;//无向图}for(int k = 1; k <= n; k++)for(int i = 1; i <= n; i++)for(int j = 1; j <= n; j++){if(ans[i][k] == -1 || ans[k][j] == -1)continue;if(ans[i][j] == -1 || ans[i][k] + ans[k][j] < ans[i][j])ans[i][j] = ans[i][k] + ans[k][j];}printf("%d\n", ans[1][n]);}return 0;
}

运行结果为:

这篇关于最短路径问题(dj和floyd算法)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/793917

相关文章

如何解决idea的Module:‘:app‘platform‘android-32‘not found.问题

《如何解决idea的Module:‘:app‘platform‘android-32‘notfound.问题》:本文主要介绍如何解决idea的Module:‘:app‘platform‘andr... 目录idea的Module:‘:app‘pwww.chinasem.cnlatform‘android-32

kali linux 无法登录root的问题及解决方法

《kalilinux无法登录root的问题及解决方法》:本文主要介绍kalilinux无法登录root的问题及解决方法,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,... 目录kali linux 无法登录root1、问题描述1.1、本地登录root1.2、ssh远程登录root2、

SpringBoot应用中出现的Full GC问题的场景与解决

《SpringBoot应用中出现的FullGC问题的场景与解决》这篇文章主要为大家详细介绍了SpringBoot应用中出现的FullGC问题的场景与解决方法,文中的示例代码讲解详细,感兴趣的小伙伴可... 目录Full GC的原理与触发条件原理触发条件对Spring Boot应用的影响示例代码优化建议结论F

openCV中KNN算法的实现

《openCV中KNN算法的实现》KNN算法是一种简单且常用的分类算法,本文主要介绍了openCV中KNN算法的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的... 目录KNN算法流程使用OpenCV实现KNNOpenCV 是一个开源的跨平台计算机视觉库,它提供了各

MySQL 中查询 VARCHAR 类型 JSON 数据的问题记录

《MySQL中查询VARCHAR类型JSON数据的问题记录》在数据库设计中,有时我们会将JSON数据存储在VARCHAR或TEXT类型字段中,本文将详细介绍如何在MySQL中有效查询存储为V... 目录一、问题背景二、mysql jsON 函数2.1 常用 JSON 函数三、查询示例3.1 基本查询3.2

Pyserial设置缓冲区大小失败的问题解决

《Pyserial设置缓冲区大小失败的问题解决》本文主要介绍了Pyserial设置缓冲区大小失败的问题解决,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面... 目录问题描述原因分析解决方案问题描述使用set_buffer_size()设置缓冲区大小后,buf

resultMap如何处理复杂映射问题

《resultMap如何处理复杂映射问题》:本文主要介绍resultMap如何处理复杂映射问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录resultMap复杂映射问题Ⅰ 多对一查询:学生——老师Ⅱ 一对多查询:老师——学生总结resultMap复杂映射问题

java实现延迟/超时/定时问题

《java实现延迟/超时/定时问题》:本文主要介绍java实现延迟/超时/定时问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录Java实现延迟/超时/定时java 每间隔5秒执行一次,一共执行5次然后结束scheduleAtFixedRate 和 schedu

如何解决mmcv无法安装或安装之后报错问题

《如何解决mmcv无法安装或安装之后报错问题》:本文主要介绍如何解决mmcv无法安装或安装之后报错问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录mmcv无法安装或安装之后报错问题1.当我们运行YOwww.chinasem.cnLO时遇到2.找到下图所示这里3.

浅谈配置MMCV环境,解决报错,版本不匹配问题

《浅谈配置MMCV环境,解决报错,版本不匹配问题》:本文主要介绍浅谈配置MMCV环境,解决报错,版本不匹配问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录配置MMCV环境,解决报错,版本不匹配错误示例正确示例总结配置MMCV环境,解决报错,版本不匹配在col