最难的工作 /// SPFA模板 oj1396】的更多相关文章

题目大意: Input 第一行是一个整数T ( T ≤ 100 ),表示测试用例的个数. 每个测试用例的第一行是两个整数 n 和 m ( 1 ≤ n ≤ 200 , 0 ≤ m ≤ 10000 ),分别表示交汇点的个数以及路的条数. 接下来的m行都有3个整数 i, j, k,表示在城市i 和城市j 之间有一条长度为k的路. 假设交汇点从1到n编号.你的出发点是1,目的地是n. 道路都是双向的. Output 每个测试用例输出一行,一个整数:逃跑的最短距离.如果无路可逃,输出-1. Sample…
SPFA模板: queue<int>Q; ]; ],sumv[]; *],__next[*],e,w[*],first[],cnts[]; void AddEdge(int U,int V,int W) { v[++e]=V; w[e]=W; __next[e]=first[U]; first[U]=e; } bool spfa(const int &s) { memset(dis,0x7f,sizeof(dis)); dis[s]=; Q.push(s); inq[s]=; ++cn…
/* SPFA模板 */ const int inf=0x3f3f3f3f; inline int SPFA(int s){ memset(dis,inf,sizeof(dis)); queue<int > q; dis[s]=; q.push(s); vis[s]=; while(!q.empty()){ int u=q.front; q.pop(); vis[u]=; for(int i=head[u];i;i=edge[i].next ){ int v=edge[i].to ; if(d…
通过stl的queue实现的spfa(vector实现邻接表存图) 本模板没有考虑存在两点不连通的情况 如果需要判断则需要用到并查集或者遍历整个邻接表 #include<iostream> #include<queue> #include<cstdio> #include<cstring> #include<vector> using namespace std; int d[10001];//存储起始点到点的最短距离 int v[10001];…
spfa作为图论中的常用算法,深受各类出题人和各位OIer的喜爱: so,为了给大众创造福利,宝宝在此奉上spfa大发的思路和模板:以感谢社会, 感谢CCF,感谢CCTV, 感谢我的老师,感谢同学们, 感谢noi,感谢noip,感谢ioi, 感谢不辞辛劳的学长学姐, 感谢帮我改程序,被我烦死的xxy ~QAQ~······and so on; 程序和图解做得比较难看,就请大家见谅了!!~(≧▽≦)/~ 谢啦!!☆⌒(*^-゜)v 思路:见程序 #include<iostream> #inclu…
一.算法步骤 建立一个队列,初始时队列里只有起始点,再建立一个数组记录起始点到所有点的最短路径(该数组的初始值要赋为极大值,该点到它本身的路径赋为0,下面的模板中该数组为dist[]).然后执行松弛操作,用队列里有的点作为起始点去刷新到所有点的最短路,如果刷新成功且被刷新点不在队列中则把该点加入到队列最后.重复执行直到队列为空. 二.算法模板 struct Edge { int s, e, dist; //边的起点.终点.长度 Edge() {} Edge(int s, int e, int d…
题目链接 题意很清晰,入门级题目,适合各种模板,可用dijkstra, floyd, Bellman-ford, spfa Dijkstra链接 Floyd链接 Bellman-Ford链接 SPFA链接 /* Name:HDU-2544-最短路 Copyright: Author: Date: 2018/4/17 10:34:47 Description: SPFA */ #include <cstring> #include <cstdio> #include <iost…
zz http://blog.sina.com.cn/s/blog_6ad20aef0100mc1a.html Spfa算法 (模板源代码) 这是Bellman Ford的改进算法.    算法介绍:建立一个队列,初始时队列里只有起始点,在建立一个表格记录起始点到所有点的最短路径(该表格的初始值要赋为极大值,该点到他本身的路径赋为0).然后执行松弛操作,用队列里有的点去刷新起始点到所有点的最短路,如果刷新成功且被刷新点不在队列中则把该点加入到队列最后.重复执行直到队列为空.     时间复杂度:…
[ACM常用模板合集] #include<iostream> #include<queue> #include<algorithm> #include<set> #include<cmath> #include<vector> #include<map> #include<stack> #include<bitset> #include<cstdio> #include<cstri…
1.UVA 558 Wormholes 2.总结:第一个spfa,好气的是用next[]数组判定Compilation error,改成nexte[]就过了..难道next还是特殊词吗 题意:科学家,虫洞.就是判定负环 #include<iostream> #include<cstring> #include<cmath> #include<queue> #include<algorithm> #include<cstdio> #de…