typedef struct graph{ int val; int weight;}graph; graph g[1005][1005],dist[1005];int visit[1005]; void dijkstra(int start,int n) { int min,u; for(int ...
分类:
编程语言 时间:
2016-10-25 02:00:47
阅读次数:
220
常用最短路算法——-SPFA和Dijkstra及其优化 这篇文章将简单讲解两个最常用的最短路优化算法,需要读者有一定的图论基础。 首先从DIJKSTRA讲起。常规的dijkstra算法复杂度较高,为O(n^2),因为要花大量时间来找当前已知的距顶点距离最小的值,所以用优先队列(值小的先出队列)来优化 ...
分类:
编程语言 时间:
2016-10-10 01:57:37
阅读次数:
283
2763: [JLOI2011]飞行路线 Description Alice和Bob现在要乘飞机旅行,他们选择了一家相对便宜的航空公司。该航空公司一共在n个城市设有业务,设这些城市分别标记为0到n-1,一共有m种航线,每种航线连接两个城市,并且航线有一定的价格。Alice和Bob现在要从一个城市沿着 ...
分类:
编程语言 时间:
2016-10-02 12:59:37
阅读次数:
272
floyd算法,关键语句只有4行的最短路算法(强行好多行)。算法的具体实现方法是枚举你两个点的起点和终点,然后枚举中间点。如果你枚举的 起点到中间点+中间点到终点 比起点到中间点小,就将起点到终点的权值替换成 起点到中间点+中间点到终点的权值,这样一直枚举下去到最后的时候就可以计算出起点到终点的权值 ...
分类:
编程语言 时间:
2016-09-28 15:12:10
阅读次数:
159
迪杰斯特拉算法(Dijkstra): Dijkstra(迪杰斯特拉)算法是典型的单源最短路径算法,用于计算一个节点到其他所有节点的最短路径。 主要特点是以起始点为中心向外层层扩展,直到扩展到终点为止。 1 #include <iostream> 2 using namespace std; 3 co ...
分类:
编程语言 时间:
2016-09-16 11:23:03
阅读次数:
245
SPFA算法 一.算法简介 SPFA(Shortest Path Faster Algorithm)算法是求单源最短路径的一种算法,它是Bellman-ford的队列优化,它是一种十分高效的最短路算法。 很多时候,给定的图存在负权边,这时类似Dijkstra等算法便没有了用武之地,而Bellman- ...
分类:
编程语言 时间:
2016-09-14 12:42:56
阅读次数:
184
SPFA是改良后的BellmanFord(在刘汝佳的入门经典2上,甚至直接将SPFA归为BellmanFord的队列优化版本。 这是算法的伪代码 ...
分类:
编程语言 时间:
2016-08-28 17:58:00
阅读次数:
257
##第二第三周暑期集训总结在第二第三周中,我主要看了状压DP,数位DP,树状DP的主要内容.同时,在做训练赛的过程中,发现一些知识点掌握的不好,于是又回头复习了一下,包括图的一些基本概念,最短路算法,并查集,最小生成树,图的存储方法(矩阵,邻接表(数组)).还有很关键的一件事就是参加了今年的CCPC... ...
分类:
其他好文 时间:
2016-08-21 21:14:33
阅读次数:
173
dijkstra(迪杰斯特拉)最短路算法是一种时间复杂度经过严格证明的最短路算法。 优化在于每次取最小值的时候采用堆优化,但是在最短路松弛过程中,dist是不断修改的,所以,为了能使复杂度降到O(nlogn),dist修改的同时,在堆中也要修改。 注意dijkstra(迪杰斯特拉)最短路算法只能用于 ...
分类:
编程语言 时间:
2016-08-17 10:18:28
阅读次数:
770
【先来一发SPFA】 int spfa_dfs(int u) { vis[u]=1; for(int k=f[u]; k!=0; k=e[k].next) { int v=e[k].v,w=e[k].w; if( d[u]+w < d[v] ) { d[v]=d[u]+w; if(!vis[v]) ...
分类:
编程语言 时间:
2016-07-28 16:19:51
阅读次数:
271