次短路 /// dijkstra oj1597
题目大意:
给出一个有向图,求从 顶点a 到 顶点b 的次短路。
第一行是2个正整数 n 和 e,表示该有向图的顶点数和边数。3 < n ≤ 5000 , 3 < e < 40000 。顶点的编号是 1 ~ n 。
接下来 e 行,每行3个正整数 u , v 和 w ,表示一条从 顶点u 指向 顶点v 的弧,权值为 w
接下来是个正整数 Q,表示接下来有Q个询问。
接下来是Q行,每行2个正整数 a 和 b,表示询问从 顶点a 到 顶点b 的次短路长度。
每个询问输出一行结果:
如果不存在次短路,则输出 no route
否则,输出从 顶点a 到 顶点b 的次短路的长度
5 9
2 3 5
1 5 5
3 5 6
1 2 8
1 3 8
5 3 4
4 1 8
4 5 3
5 4 2
6
2 5
1 2
3 1
5 4
1 5
5 2
16
23
21
7
10
23
原本的dis[]数组记录最短路,改为开两个数组dis1[],dis2[]分别记录最短路和次短路
本题还有一个优化操作 因为是多个询问 所以另开一个邻接表记录已经搜索过的从某点出发的次短路
#include <bits/stdc++.h>
#define INF 0x3f3f3f3f
#define mp(i,j) make_pair(i,j)
#define P pair<int,int>
using namespace std;
int n,e,dis1[],dis2[];
vector <P> vec[], got[]; // vec为图的邻接表 got为已搜过的次短路
void save(int a)
{
for(int i=;i<=n;i++) /// 将已经得到的次短路结果记录下来
got[a].push_back(mp(i,dis2[i]));
}
void dijk(int a,int b)
{
memset(dis1,INF,sizeof(dis1));
memset(dis2,INF,sizeof(dis2));
priority_queue <P, vector<P>, greater<P> > q;
// 使用pair好处在于 默认对.first排序 使用greater<>升序排序
q.push(mp(,a)); dis1[a]=; while(!q.empty()) {
P u=q.top(); q.pop();
if(dis2[u.second]<u.first) continue; vector <P> ::iterator it;
for(it=vec[u.second].begin();it!=vec[u.second].end();it++) {
int w=u.first+(*it).first;
int sec=(*it).second;
if(w<dis1[sec]) {
swap(dis1[sec],w);
q.push(mp(dis1[sec],sec));
}
if(w<dis2[sec]) {
swap(dis2[sec],w);
q.push(mp(dis2[sec],sec));
}
}
}
if(dis2[b]==INF) printf("no route\n");
else printf("%d\n",dis2[b]);
save(a);
}
int main()
{
scanf("%d%d",&n,&e);
while(e--) {
int u,v,w; scanf("%d%d%d",&u,&v,&w);
vec[u].push_back(mp(w,v));
}
int q; scanf("%d",&q);
while(q--) {
int a,b; scanf("%d%d",&a,&b);
if(got[a].size()>) { /// 已经搜过 直接从got中寻找结果
for(int i=;i<got[a].size();i++)
if(got[a][i].first==b) {
if(got[a][i].second==INF) printf("no route\n");
else printf("%d\n",got[a][i].second);
break;
}
}
else dijk(a,b); /// 否则dijk一下
} return ;
}
次短路 /// dijkstra oj1597的更多相关文章
- hdu 2544 最短路 Dijkstra
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=2544 题目分析:比较简单的最短路算法应用.题目告知起点与终点的位置,以及各路口之间路径到达所需的时间, ...
- 算法学习笔记(三) 最短路 Dijkstra 和 Floyd 算法
图论中一个经典问题就是求最短路.最为基础和最为经典的算法莫过于 Dijkstra 和 Floyd 算法,一个是贪心算法,一个是动态规划.这也是算法中的两大经典代表.用一个简单图在纸上一步一步演算,也是 ...
- 单源最短路dijkstra算法&&优化史
一下午都在学最短路dijkstra算法,总算是优化到了我能达到的水平的最快水准,然后列举一下我的优化历史,顺便总结总结 最朴素算法: 邻接矩阵存边+贪心||dp思想,几乎纯暴力,luoguTLE+ML ...
- HUD.2544 最短路 (Dijkstra)
HUD.2544 最短路 (Dijkstra) 题意分析 1表示起点,n表示起点(或者颠倒过来也可以) 建立无向图 从n或者1跑dij即可. 代码总览 #include <bits/stdc++ ...
- 训练指南 UVALive - 4080(最短路Dijkstra + 边修改 + 最短路树)
layout: post title: 训练指南 UVALive - 4080(最短路Dijkstra + 边修改 + 最短路树) author: "luowentaoaa" ca ...
- 训练指南 UVA - 10917(最短路Dijkstra + 基础DP)
layout: post title: 训练指南 UVA - 10917(最短路Dijkstra + 基础DP) author: "luowentaoaa" catalog: tr ...
- 训练指南 UVA - 11374(最短路Dijkstra + 记录路径 + 模板)
layout: post title: 训练指南 UVA - 11374(最短路Dijkstra + 记录路径 + 模板) author: "luowentaoaa" catalo ...
- 最短路Dijkstra算法的一些扩展问题
最短路Dijkstra算法的一些扩展问题 很早以前写过关于A*求k短路的文章,那时候还不明白为什么还可以把所有点重复的放入堆中,只知道那样求出来的就是对的.知其然不知其所以然是件容易引发伤痛的 ...
- 华夏60 战斗机(最短路dijkstra)
华夏60 战斗机(最短路dijkstra) 华夏60 超音速战斗机是当今世界上机动性能最先进的战斗机.战斗过程中的一个关键问题是如何在最短的时间内使飞机从当前的飞行高度和速度爬升/俯冲到指定的高度并达 ...
随机推荐
- 莫比乌斯反演+二维前缀和——hdu4746二刷
第二次做这题,求前缀和的时候还是卡住了 fg函数的反演是可以直接用莫比乌斯基本代换式来代换的 #include<bits/stdc++.h> using namespace std; #d ...
- jar中没有主清单属性【解决办法】
<plugin> <groupId>org.apache.maven.plugins</groupId> <artifactId>maven-compi ...
- NX二次开发-UFUN写入本地文本文档uc4524
1 NX9+VS2012 2 3 #include <uf.h> 4 #include <uf_cfi.h> 5 #include <uf_ui.h> 6 7 us ...
- (转)虚拟IP原理
转:http://blog.csdn.net/whycold/article/details/11898249 高可用性HA(High Availability)指的是通过尽量缩短因日常维护操作(计划 ...
- 秦曾昌人工智能课程---5、KNN和朴素贝叶斯
秦曾昌人工智能课程---5.KNN和朴素贝叶斯 一.总结 一句话总结: 拟合和概率:构建机器学习模型,一般有拟合和概率两种方式 轻学无用:一定要保证学有所用,要深入学习,比如之前做的安卓,一定要学通, ...
- Java io简单总结
IO 字节流在操作时本身不会用到缓冲区(内存),是文件本身直接操作的 字符流在操作时使用了缓冲区,通过缓冲区再操作文件 缓冲:一段特殊的内存.如果一个程序频繁地操作一个资源(如文件或数据库),则性能会 ...
- CSS3:CSS3 渐变(Gradients)
ylbtech-CSS3:CSS3 渐变(Gradients) 1.返回顶部 1. CSS3 渐变(Gradients) CSS3 渐变(gradients)可以让你在两个或多个指定的颜色之间显示平稳 ...
- 简单实用的makefile
简单的makefile 为了说明问题,就新建一组文件如下: 文件布局及运行结果: make clean 按目录归置 文件看起来是是清楚了,但是makefile写得揪心. 实用版 (1)Makefile ...
- Spring Cloud Eureka 注册安全一定要做到位!
/eureka/ 参考配置如下: defaultZone: http://javastack:javastack@eureka1:8761/eureka/, http://javastack:java ...
- 如何查看jdk版本和路径
cmd进入命令提示符,查看jdk版本,输入java -version;查看jdk路径 ,输入set java home.,这个也是默认路径