1111 Online Map
题意:给定一个图,以及起点和终点,需要我们计算两条路径。第1条路径:距离最短路径,若不唯一,则选择用时最短的那一条;第2条路径:用时最少路径,若不唯一,选择经过结点数最少的那一条。
思路:两次Dijkstra即可。以往都是求一条路径,本题要求两条,没什么不同,只是代码量多了一些。编写代码前要心中有数,变量名怎么命名等等(变量名一多,命名真是件举棋不定的事。。)
第1条路径:第1标尺为距离,第2标尺为用时,在Dijkstra中完成更新。用pre[v]记录结点v的前驱,在Dijkstra之后用DFS把路径提取出来即可。
第2条路径:第1标尺为用时,第2标尺为整条路径所经过的结点数,也可以在Dijkstra中完成更新。其他操作都是一模一样的。
#include <cstdio>
#include <vector>
#include <algorithm>
using namespace std;
const int Inf=0x7fffffff;
;
struct Node{
int v;
int length,time;
Node(int v_,int len_,int t_):v(v_),length(len_),time(t_){}
};
int n,m,s,e;//结点个数,边数,起点,终点
vector<Node> Adj[N];
bool vis[N];
vector<int> pre[N];
//dis[v]记录起点s到结点v的最短距离(第1标尺),cost[v]记录起点s到结点v的最快时间(第2标尺)
int dis[N];
int cost[N];
//time[v]记录起点s到结点v的最快时间(第1标尺),num[v]记录起点s到结点v的最少结点数(第2标尺)
int time[N];
int num[N];
void Dijkstra_length(int s)
{
fill(vis,vis+N,false);
fill(dis,dis+N,Inf);
dis[s]=;
fill(cost,cost+N,Inf);
cost[s]=;
;i<n;i++){
,min=Inf;
;v<n;v++){
if(!vis[v] && dis[v]<min){
min=dis[v];
u=v;
}
}
) return;
vis[u]=true;
for(auto node:Adj[u]){//u-v
int v=node.v, len=node.length, time=node.time;
if(!vis[v]){
if(dis[u]+len < dis[v]){
dis[v] = dis[u]+len;
cost[v] = cost[u]+time;
pre[v].clear();
pre[v].push_back(u);
}else if(dis[u]+len == dis[v] && cost[u]+time < cost[v]){
cost[v] = cost[u]+time;
pre[v].clear();
pre[v].push_back(u);
}
}
}
}
}
void Dijkstra_time(int s)
{
fill(vis,vis+N,false);
fill(time,time+N,Inf);
time[s]=;
fill(num,num+N,Inf);
num[s]=;
;i<n;i++){
,min=Inf;
;v<n;v++){
if(!vis[v] && time[v]<min){
min=time[v];
u=v;
}
}
) return;
vis[u]=true;
for(auto node:Adj[u]){//u-v
int v=node.v, len=node.length, t=node.time;
if(!vis[v]){
if(time[u]+t < time[v]){
time[v] = time[u]+t;
num[v]=num[u]+;
pre[v].clear();
pre[v].push_back(u);
} < num[v]){
num[v]=num[u]+;
pre[v].clear();
pre[v].push_back(u);
}
}
}
}
}
//用于提取路径
void dfs(int v,vector<int>& path)
{
path.push_back(v);
for(auto u:pre[v])
dfs(u,path);
}
int main()
{
//freopen("pat.txt","r",stdin);
int v1,v2,one_way,len,t;
scanf("%d%d",&n,&m);
;i<m;i++){
scanf("%d%d%d%d%d",&v1,&v2,&one_way,&len,&t);
if(one_way){
Adj[v1].push_back(Node(v2,len,t));
}else{
Adj[v1].push_back(Node(v2,len,t));
Adj[v2].push_back(Node(v1,len,t));
}
}
scanf("%d%d",&s,&e);
vector<int> path_len,path_time;//分别记录两条路径
Dijkstra_length(s);
dfs(e,path_len);
Dijkstra_time(s);
dfs(e,path_time);
if(path_len==path_time){
printf("Distance = %d; Time = %d:",dis[e],time[e]);
;i>=;i--){
printf(" %d",path_time[i]);
) printf(" ->");
else printf("\n");
}
}else{
printf("Distance = %d:",dis[e]);
;i>=;i--){
printf(" %d",path_len[i]);
) printf(" ->");
else printf("\n");
}
printf("Time = %d:",time[e]);
;i>=;i--){
printf(" %d",path_time[i]);
) printf(" ->");
else printf("\n");
}
}
;
}
1111 Online Map的更多相关文章
- 1111 Online Map (30 分)
1111. Online Map (30)Input our current position and a destination, an online map can recommend sever ...
- 1111 Online Map (30 分)
1111 Online Map (30 分) Input our current position and a destination, an online map can recommend sev ...
- PAT甲级1111. Online Map
PAT甲级1111. Online Map 题意: 输入我们当前的位置和目的地,一个在线地图可以推荐几条路径.现在你的工作是向你的用户推荐两条路径:一条是最短的,另一条是最快的.确保任何请求存在路径. ...
- PAT 1111 Online Map[Dijkstra][dfs]
1111 Online Map(30 分) Input our current position and a destination, an online map can recommend seve ...
- PAT甲级——1111 Online Map (单源最短路经的Dijkstra算法、priority_queue的使用)
本文章同步发布在CSDN:https://blog.csdn.net/weixin_44385565/article/details/90041078 1111 Online Map (30 分) ...
- PAT (Advanced Level) 1111. Online Map (30)
预处理出最短路再进行暴力dfs求答案会比较好.直接dfs效率太低. #include<cstdio> #include<cstring> #include<cmath&g ...
- 1111. Online Map (30)
Input our current position and a destination, an online map can recommend several paths. Now your jo ...
- 1111 Online Map (30)(30 分)
Input our current position and a destination, an online map can recommend several paths. Now your jo ...
- PAT 1111 Online Map
Input our current position and a destination, an online map can recommend several paths. Now your jo ...
- PAT Advanced 1111 Online Map (30) [Dijkstra算法 + DFS]
题目 Input our current position and a destination, an online map can recommend several paths. Now your ...
随机推荐
- spring3: AOP 之代理机制
Spring AOP通过代理模式实现,目前支持两种代理:JDK动态代理.CGLIB代理来创建AOP代理,Spring建议优先使用JDK动态代理. JDK动态代理:使用java.lang.reflect ...
- KMP算法--C#版
static void BuildTable(string subString, ref int[] next) { if (string.IsNullOrWhiteSpace(subString)) ...
- MacOS Docker安装
Docker简介: Docker 是一个开源的应用容器引擎 Docker 可以让开发者打包他们的应用以及依赖包到一个轻量级.可移植的容器中,然后发布到任何流行的 Linux 机器上,也可以实现虚拟化. ...
- 【专题】区间dp
1.[nyoj737]石子合并 传送门:点击打开链接 描述 有N堆石子排成一排,每堆石子有一定的数量.现要将N堆石子并成为一堆.合并的过程只能每次将相邻的两堆石子堆成一堆,每次合并花费的代价为这 ...
- hdu4185
题解:每两个联通的油井建边 然后二分图最大匹配 最后答案除以2 代码: #include<cstdio> #include<cmath> #include<cstring ...
- Spring 自动装配;方法注入
通过配置defalut—autowire属性,Spring IOC容器可以自动为程序注入Bean:默认是no(不启用自动装配). default—autowire的类型有: byName:通过名称自动 ...
- scrapy结构及各部件介绍
1.总览,数据流图: 2.Engine:引擎负责控制系统所有组件之间的数据流,并在发生某些操作时触发事件. 3.Scheduler:调度程序接收来自引擎的请求,并将它们排入队列,并在之后,当Engin ...
- 【转载】Git,Github和Gitlab简介和基本使用Gitlab安装和使用
http://blog.csdn.net/u011241606/article/details/51471367
- Oracle中的填充函数lpad和rpad的用法(转)
原文链接:http://blog.csdn.net/myzhanglt/article/details/7392999 今日学习遇到一个不熟悉的函数LPAD,查了一下文档,将其用法总结如下: Lpad ...
- jQuery对象[0]倒底是什么?
s[0]倒底是什么?(s为jQuery对象)代码:var s=$("div"); alert(s.length);alert(s[0]); jQuery对象默认都有个0索引,s为j ...