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 ...
随机推荐
- Treflection02_getMethods()_getMethod()
1. package reflectionZ; import java.lang.reflect.Constructor; import java.lang.reflect.Method; impor ...
- ubantu中让g++支持c++11的办法
g++ main.cpp -std=c++11 -o a 其中: main.cpp是要编译的源文件 a是编译后的文件名 注意-std=c++11不要写成-std=c11
- ps(笔记)
窗口 工作区 默认窗口(恢复) ctrl + n 点阵图(像素图) 小方格组成的 alt 键 配合 放大缩小 ppi dpi 打印输出. 画布新建 z键 局部放大 右击实际像素操作 f键 全屏 空格键 ...
- Spring mvc使用不了jstl 或者 Spring mvc不解析jstl
最近我搭了一个maven的springMVC的项目发现前端怎么也识别不了我的jstl,我查询了很多方法,导致这种情况的原因有很多 1.jar引用不对,maven中的正确导入可用的jar <dep ...
- react-router路由
1.http://blog.csdn.net/sunshine215/article/details/78296404(react-router v4 使用 history 控制路由跳转) 2.htt ...
- 移植 MIUI Framework
移植MIUI Framework 原文:http://www.miui.com/thread-409543-1-1.html 1. 为什么使用代码插桩 首先我们来回顾第一章中的Android软件架构图 ...
- 从零开始编写深度学习库(五)Eigen Tensor学习笔记2.0
1.extract_image_patches函数的使用: 假设Eigen::Tensor形状为(3,8,8,9),现在要对第二维.第三维根据size大小为(2,2),stride=(2,2),那么如 ...
- mac brew安装使用卸载
(一)安装 1.浏览器打开brew.sh,进入homebrew主页.找到install homebrew 的命令: /usr/bin/ruby -e "$(curl -fsSL https: ...
- C++中strftime()的详细说明
我们可以使用strftime()函数将时间格式化为我们想要的格式.它的原型如下: size_t strftime( char *strDest, size_t maxsize, const char ...
- python学习之面向对象(下)
该篇主要是针对面向对象的细讲,包括类的多重继承,方法的重写,析构函数,回收机制进行讲解 #该类主要是讲述python面象对象的一些特征,包括继承,方法的重写,多态,垃圾回收 class person( ...