7-2 单源最短路径 (10 分)(思路+详解+邻接表做法)Come Brather!!!!!!!!!!

一:前言

本次题解先展示用邻接矩阵做的,但其会出现内存超限,因为确实是临界矩阵在数据很大的时候相比临界表是耗内存的,但是以前习惯用临界矩阵了,所以一上来就用临界矩阵做了,后来上网查了后知道邻接矩阵会内存超限,所以后来又用邻接表写了一遍。

二:题目

请编写程序求给定正权有向图的单源最短路径长度。图中包含n个顶点,编号为0至n-1,以顶点0作为源点。

输入格式:
输入第一行为两个正整数n和e,分别表示图的顶点数和边数,其中n不超过20000,e不超过1000。接下来e行表示每条边的信息,每行为3个非负整数a、b、c,其中a和b表示该边的端点编号,c表示权值。各边并非按端点编号顺序排列。

输出格式:
输出为一行整数,为按顶点编号顺序排列的源点0到各顶点的最短路径长度(不含源点到源点),每个整数后一个空格。如源点到某顶点无最短路径,则不输出该条路径长度。

输入样例:

4 4
0 1 1
0 3 1
1 3 1
2 0 1

输出样例:

1 1 

三:介绍dijkstra算法

1.dijkstra

无论你用哪种数据结构存储数据,其算法思想是一样的,dijkstra算法,单源点最短路径,其在更新的阶段体现了贪心,每次都找最优的结,即最小的路径

2:做题思路

思路:1.首先读题分析到 这是一个有向图
2.单源点最短路径:确定一个点为源点,其到其他点的最短路径;本题当中
因为是有向图,当没有最短路径就不输出了

分析:示例: 4 4
0 1 1
0 3 1
1 3 1
2 0 1

输出为: 1 1

这是0 到 1 的最短路径和0到3的最短路径 而 0到 2无路径 (2到0有路径)
3.本题我先用的是临界矩阵储存数据的会出现内存超限后来改为邻接表,而体现贪心的部分是代码中的更新的部分,每次都找最优解
4.具体代码流程需要自己分析示例图解:这里有我分析的无向图的图解,思路和有向图类似
懂了这个就懂了本题的写码思路了

3.图示(以无向图为例,和有向图思路是一致的)

在这里插入图片描述

四:上码

1.用邻接矩阵存储的数据(会出现内存超限)

/**思路:1.首先读题分析到 这是一个有向图2.单源点最短路径:确定一个点为源点,其到其他点的最短路径;本题当中因为是有向图,当没有最短路径就不输出了分析:示例:	4 40 1 10 3 11 3 12 0 1	输出为:    1 1 	这是0 到 1 的最短路径和0到3的最短路径  而 0到 2无路径 (2到0有路径)	3.本题我用的是临界矩阵储存数据的,而体现贪心的部分是代码中的更新的部分,每次都找最优解 4.具体代码流程需要自己分析示例图解:这里有我分析的无向图的图解,思路和有向图类似懂了这个就懂了本题的写码思路了								   */ #include<bits/stdc++.h>using namespace std;typedef struct Graph * PtrGraph;  typedef struct Graph{int Nv;int Ne;int Date[2276][2274];} graph;int infinite = 99999;//初始化临界矩阵void CreateGraph(PtrGraph G){cin >> G->Nv >> G->Ne;//初始化临界矩阵 for(int i = 0; i < G->Nv; i++){for(int j = 0; j < G->Nv; j++){if(i == j){G->Date[i][j] = 0;} else{G->Date[i][j] = infinite;//当两个点不相连的时候为无穷大 }} }//向临界矩阵中赋值for(int k = 0; k < G->Ne; k++){int i,j,w;cin >> i >> j >> w;G->Date[i][j] = w;//这里体现有向图,即从 i 到 j 在临界矩阵中有值,而从j到i无值 		} } //验证输出临界矩阵 // void print_Graph(PtrGraph G) {// 	 	for(int i = 0; i < G->Nv; i++){// 			for(int j = 0; j < G->Nv; j++){// 			cout << G->Date[i][j] << ' ';// 		} // 		cout << endl;// 	}// }//核心代码 体现贪心的代码 每次更新均找距离最短的点 void dijkstra(PtrGraph G){int dist[2001];//用于存储源点到各个点的最短距离int visited[2001];//用于记录已经访问了哪个点的 for(int i = 0; i < G->Nv; i++){dist[i] = G->Date[0][i];//题目给出了源点是 0  } visited[0] = 1;//表示1已经访问过了//更新 while(1){int m = -1;int min = infinite;for(int i = 0; i < G->Nv; i++){if(visited[i] != 1 && dist[i] < min){min = dist[i];m = i;	}			} if(m == -1){//如果m无变化,说明图中的各点已经更新完了 break;}visited[m] = 1;for(int i = 0; i < G->Nv; i++){if(visited[i] != 1 && min + G->Date[m][i] < dist[i]){//这里注意  min + G->Date[m][i]://表示了一个源点到其最短的距离(min)的点,//然后需要判断这个点到其他点的距离加上min和源点到其他点的距离进行比较更新dist[i] = min + G->Date[m][i];}} } for(int i = 1; i < G->Nv; i++){if(dist[i] == infinite)continue;else{cout << dist[i] << ' '; 		}		}	} int main(){PtrGraph G = (PtrGraph)malloc(sizeof(struct Graph));CreateGraph(G);//	print_Graph(G);dijkstra(G);} 

2:用邻接表存的正确结果

#include<bits/stdc++.h>
using namespace std;
#define max 20001struct Node{int to;//指向边的结点 int val;//边的权值 int next;//指向下一个结点的下标 
} node[max];int head[max],n,m,num = 0;
int infinite = 99999;//建立邻接表 
void add(int from,int to,int val){num++;node[num].to = to;node[num].val = val;node[num].next = head[from];head[from] = num;//更新head的值,当再有从from连接的点 它的下一个为 num 坐标 
} //dij算法
void dijkstra(){int dist[max];fill(dist, dist + 20001, infinite);int vis[max] = {0};for(int i = head[0]; i != 0; i = node[i].next){//这里是选取源点为0的顶点,将和其相连边的权值存进去了 dist[node[i].to] = node[i].val;   //比如:0到1:即 node[i].to = 1表示的是顶点, node[i].val = 1 表示0到1这条边的权值为1;dist[1] = 1}vis[0] = 1;while(1){int m = -1;int min = infinite;for(int i = 0; i < n; i++){if(vis[i] != 1 && dist[i] < min){min = dist[i];m = i;}}if(m == -1){//已经遍历完了所有结点 break;}vis[m] = 1;//确定m这个顶点 接下来遍历 m这个结点的链表 for(int i = head[m]; i != 0; i = node[i].next){if(vis[node[i].to] != 1 && min + node[i].val < dist[node[i].to]){//vis[node[i].to] != 1如果出现 1到2 和2到1这种情况,那么当1已经遍历过,在顶点为2的这个链表中就不用再遍历了dist[node[i].to] = min + node[i].val;}	} 		} for(int i = 0; i < n; i++){if(dist[i] != infinite){cout << dist[i] << ' ';}}		
} int main(){memset(head,0,sizeof(head));cin >> n >> m;for(int i = 0; i < m; i++){int from,to,val;cin >> from >> to >> val;add(from,to,val);} //测试邻接表的数据是否正确 
//	for(int i = 0; i < n; i++){
//		cout << i << ' ';
//		for(int j = head[i]; j != 0; j = node[j].next){
//			cout << node[j].to << ' ' << node[j].val << ' '; 
//		}
//		cout << endl;
//	}dijkstra();}//4 4
//0 1 1
//0 3 1
//1 3 1
//2 0 1//邻接表输出的数据 
//0 3 1 1 1
//1 3 1
//2 0 1
//3//4 5
//0 1 1
//1 3 2
//0 3 4
//0 2 2
//2 3 3

在这里插入图片描述

五:知识速递(如果兄弟们对邻接表不熟悉,可以学习下哈)

邻接表的用法

加油 兄弟们!!!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/308174.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

在.NET Core中使用MongoDB明细教程(3):Skip, Sort, Limit, Projections

到目前为止&#xff0c;我们已经讨论了创建文档, 检索文档&#xff0c;现在让我们来研究一下文档排序&#xff0c;指定要跳过或限制返回的文档数量&#xff0c;以及如何进行投影。此篇文章中的实例代码摘录自原文&#xff0c;未像前几篇文章一样进行实际代码的验证。作者&#…

map容器的使用 逆序遍历map容器当中的数据

一&#xff1a;前言 这个逆序遍历是将map容器的迭代器进行了变化&#xff0c;reverse_iterator逆向遍历的迭代器 &#xff0c;它需要 rbegin()和rend()方法指出反向遍历的 起始位置和终止位置。 二&#xff1a;上码演示 #include<bits/stdc.h> using namespace std;in…

递归优化的这三种方式你知道吗?

估计找工作的&#xff0c;都会碰到面试官老是问道“递归算法”&#xff0c;感同身受&#xff0c;前段时间面试的时候&#xff0c;就有一家问道这个问题&#xff0c;是非常典型的问题。在前面一篇世界上有哪些代码量很少&#xff0c;但很牛逼很经典的算法或项目案例&#xff1f;…

7-7 硬币找钱问题 (10 分)(思路+详解+double类型数据的处理)Come baby!!!!!!!!!!!!!!!!!!!!

一&#xff1a;题目 设有6 种不同面值的硬币&#xff0c;各硬币的面值分别为5 分&#xff0c;1 角&#xff0c;2 角&#xff0c;5 角&#xff0c;1 元&#xff0c;2元。现要用这些面值的硬币来购物。在购物中希望使用最少个数硬币。例如&#xff0c;1 次购物需要付款0.55 元&a…

7-6 区间覆盖 (10 分)(思路+详解)Come 宝!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!

一&#xff1a;题目 设 x 1 ​ ,x 2 ​ ,…,x n ​ 是实直线上的n个点。用固定长度的闭区间覆盖这n个点&#xff0c;至少需要多少个这样的固定长度闭区间&#xff1f; 输入格式: 第1行有2个正整数n(n<50)和k&#xff0c;表示有n个点&#xff0c;且固定长度闭区间的长度为k…

你有 GitHub 帐号么?平时都用它来干什么?

这是头哥侃码的第212篇原创上个月&#xff0c;我写了一篇 #与抑郁症斗争的那些年&#xff0c;我也曾想去死一死#&#xff0c;分享了自己在创业失败那段时间的抑郁焦虑的经历。很显然&#xff0c;这已经不是我第一次把自己的悲惨经历写出来了。在文章推送后&#xff0c;有读者在…

7-5 汽车加油问题 (20 分)(思路+详解)Come 宝!!!!!!!!!!!!!

一&#xff1a;题目 题目来源&#xff1a;王晓东《算法设计与分析》 一辆汽车加满油后可行驶 n公里。旅途中有若干个加油站。设计一个有效算法&#xff0c;指出应 在哪些加油站停靠加油&#xff0c;使沿途加油次数最少。 输入格式: 第一行有 2 个正整数n和 k&#xff08;k&l…

在生产环境下处理EFCore数据库迁移的五种方法

在生产环境下处理EFCore数据库迁移的五种方法原文链接&#xff1a;https://www.thereformedprogrammer.net/handling-entity-framework-core-database-migrations-in-production-part-1/作者:Jon P Smith&#xff0c;是《 Entity Framework Core in Action》的作者安德鲁洛克&a…

计算机系统结构答案汤志忠,计算机系统结构(第2版)郑伟明汤志忠课后习题答案以及例题收录.doc...

计算机系统结构(第2版)郑伟明汤志忠课后习题答案以及例题收录.doc 1计算机系统结构第2版郑伟明汤志忠编著清华大学出版社习题解答21目录11第一章P331719(透明性概念)&#xff0c;112118(AMDAHL定律)&#xff0c;119、121、124(CPI/MIPS)12第二章P12423、25、26(浮点数性能)&…

7-1 活动选择问题 (25 分)(思路+详解+扩展)宝 今天你AC了吗!!!

一&#xff1a;题目 假定一个有n个活动(activity)的集合S{a 1 ​ ,a 2 ​ ,…,a n ​ }&#xff0c;这些活动使用同一个资源&#xff08;例如同一个阶梯教室&#xff09;&#xff0c;而这个资源在某个时刻只能供一个活动使用。每个活动a i ​ 都有一个开始时间s i ​ 和一个结…

初识ABP vNext(5):ABP扩展实体

点击上方蓝字"小黑在哪里"关注我吧扩展实体路由整理前言上一篇实现了前端vue部分的用户登录和菜单权限控制&#xff0c;但是有一些问题需要解决&#xff0c;比如用户头像、用户介绍字段目前还没有&#xff0c;下面就来完善一下。开始因为用户实体是ABP模板自动生成的…

7-8 最优服务次序问题 (10 分)

一 &#xff1a;题目 设有n 个顾客同时等待一项服务。顾客i需要的服务时间为 t i ​ (1<i<n) 。应如何安排n个顾客的服务次序才能使平均等待时间达到最小&#xff1f;平均等待时间是n 个顾客等待服务时间的总和除以n。 输入格式: 第一行是正整数n(1<n<1000)&…

.NET Core + K8S + Apollo 玩转配置中心

1.引言Apollo&#xff08;阿波罗&#xff09;是携程框架部门研发的分布式配置中心&#xff0c;能够集中化管理应用不同环境、不同集群的配置&#xff0c;配置修改后能够实时推送到应用端&#xff0c;并且具备规范的权限、流程治理等特性&#xff0c;适用于微服务配置管理场景。…

计算机格式化后数据恢复的基础,电脑硬盘格式化后还能恢复吗

电脑硬盘是电脑运行的基础固件&#xff0c;我们使用电脑需要依赖它储存文件、运行软件等。那么在使用电脑的过程中你有没有遇到这样的问题&#xff1a;当打开一个电脑磁盘分区时&#xff0c;该分区无法使用并提示格式化&#xff0c;这时候一般的小伙伴是不是都手欠格式化硬盘了…

路线错误的教训对如今的模范企业也有借鉴意义

此前&#xff0c;倪光南院士对L公司如今的困境做了深刻的剖析&#xff0c;那就是“路线不对”、“知识产权0股份”。“路线不对”指的是L公司放弃了技术路线&#xff0c;选择了“造不如买”&#xff0c;玩组装和贸易。几十年如一日依附于Wintel体系&#xff0c;“跟在洋人身后吃…

7-3 最小生成树-kruskal (10 分)(思路+详解+并查集详解+段错误超时解决)宝 Come

一&#xff1a;前言 本题需要用到并查集的知识&#xff0c;建议先学完并查集后再看看本题 二&#xff1a;题目 题目给出一个无向连通图&#xff0c;要求求出其最小生成树的权值。 温馨提示&#xff1a;本题请使用kruskal最小生成树算法。 输入格式: 第一行包含两个整数 N(1&…

计算机等级delphi取消,计算机二级DELPHI控件:DELPHI过滤记录的实现方法

所谓过滤就是从表中选取满足特定条件的部分记录。过滤记录首先要通过Filter。属性设置过滤条件&#xff0c;然后将Filtered属性设置为True&#xff0c;即可从数据集组件连接的表中过滤出满足条件的记录。1&#xff0e;Filter属性Filter属性用于设置过滤条件&#xff0c;它是一个…

Azure认知服务之使用墨迹识别功能识别手写汉字

前面我们使用Azure Face实现了人脸识别、使用Azure表格识别器提取了表格里的数据。这次我们试试使用Azure墨迹识别API来对笔迹进行识别。墨迹识别墨迹识别器认知服务提供基于云的 REST API 用于分析和识别数字墨迹内容。与使用光学字符识别 (OCR) 的服务不同&#xff0c;该 API…

7-9 删数问题 (10 分)(思路加详解)

一&#xff1a;题目 有一个长度为n&#xff08;n < 240&#xff09;的正整数&#xff0c;从中取出k&#xff08;k < n&#xff09;个数&#xff0c;使剩余的数保持原来的次序不变&#xff0c;求这个正整数经过删数之后最小是多少。 输入格式: n和k 输出格式: 一个数字…

【LeetCode】1. 盛最多水的容器:C#三种解法

题目&#xff1a;https://leetcode-cn.com/problems/container-with-most-water/盛最多水的容器难度:中等给你 n 个非负整数 a1&#xff0c;a2&#xff0c;...&#xff0c;an&#xff0c;每个数代表坐标中的一个点 (i, ai) 。在坐标内画 n 条垂直线&#xff0c;垂直线 i 的两个…