DIj】的更多相关文章

纯最短路. ///HDU 2544堆优化的最短路 #include <cstdio> #include <iostream> #include <sstream> #include <cmath> #include <cstring> #include <cstdlib> #include <string> #include <vector> #include <map> #include <…
把我坑到死的题 开始开题以为是全图连通是的最小值 ,以为是最小生成树,然后敲了发现不是,看了下别人的题意,然后懂了: 然后发现数据大,要用邻接表就去学了一下邻接表,然后又去学了下优先队列优化的dij: 这坑爹的题目我交了10几遍,也不知道错在哪里:后来知道了maxint要#define Maxint 10000000000: 然后long int 是过不了的,改成long long才能过 ,真是呵呵啊: #include<stdio.h> #include<string.h> #i…
输入一个无向图<V,E>    V<=1e5, E<=3e5 现在另外给k条边(u=1,v=s[k],w=y[k]) 问在不影响从结点1出发到所有结点的最短路的前提下,最多可以删除k条边的多少条 跑最短路的时候维护或者统计就好了 一开始用spfa.然后TLE 45...好久没写  Dij+堆优化   ... p.s.优先队列默认大顶堆 Dij+堆优化   264ms #include <cstdio> #include <cstring> #include…
Description 老S在某城市生活的非常不自在,想趁着ICPC举办期间在省内转转.已知老S所在的省有N个城市,M条无向边(对于某一对结点可能出现重边).由于省内的交通相当糟糕,通过某条边所需要花费的时间受到一天中不同时刻的影响.此外对于某一时刻(一天24小时的任意一个整点算一个时刻),从任何方向通过无向边所需要的时间相同.现在老S想请你帮他规划一下旅行路线. Input 第一行输入为一个整数T表示测试个数T 对于每一个测试的第一行为3个整数N,M,K,其中K表示老S的询问数 之后有2M行,…
题目链接:51nod 1445 变色DNA 看了相关讨论再去用最短路:val[i][j]之间如果是'Y',说明i可以到达j,并且i到达j的代价是i那行 1到j-1 里面'Y'的数量. 最后,求 0到n-1的最短路. 感觉读懂了题意就真的简单了.. #include<cstdio> #include<cstring> #include<algorithm> #include<vector> #include<queue> #define CLR(a…
题目链接:51nod 1459 迷宫游戏 dij裸题. #include<cstdio> #include<cstring> #include<algorithm> #include<vector> #include<queue> #define CLR(a,b) memset((a),(b),sizeof((a))) using namespace std; const int inf = 0x3f3f3f3f; ; int d[N], vis…
#include <iostream> #include <cstdio> #include <cstdlib> #include <algorithm> #include <cstring> #include <cmath> #include <vector> #include <queue> #include <stack> #include <set> #include <m…
题意:有n个电梯,目的地是第K层(起点是第0层),给出每个电梯的速度,以及每个电梯能到达的层数,如果中途需要换电梯的话,时间需要+60,求到达目的地的最短时间: 思路:Dij求最短路.如果是另一条路比较短的话,相当于乘别的电梯,也就是再+60,自己不可能和自己比,即d[e.v] 和 d[e.u] + d + 60比较即可: #include <iostream> #include <cstdio> #include <cstring> #include <stri…
题意:赛车背景,给你n个节点,m条边的图以及起点和终点:其中每条边的信息包括u(起点),v(终点),a(开启的时间),b(关闭的时间),d(通过这条道路的时间):求最短通过的时间,其中车在进的时候,保证时间足够能走出去:否则需要等一些分钟: 思路:dij真是万能的,把固定权值改成动态的即可: 其中改变权值的语句很关键,并且推出的规律有个前提就是保证道路打开的时间一定大于等于通过该条道路的时间,否则相当于道路不通,被我忽略了,WA了3遍,可惜: #include <iostream> #incl…
既然输入的是损坏率,那1-x就是剩余的.最后只要剩余的最大. #include<stdio.h> #include<string.h> #define Max 99999999 ; double dis[maxn],map[maxn][maxn]; int vis[maxn],n,val[maxn]; void init() { int i,j; ;i<=n;i++) ;j<=n;j++) if(i==j) map[i][j]=; ; } void dij() { in…