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 ...
随机推荐
- java Graphics2d消除锯齿,使字体平滑显示
Java 2D API 提供的文本处理功能进行美化.Java 2D API 的文本功能包括: 使用抗锯齿处理和微调(hinting)以达到更好的输出质量 可以使用系统安装的所有字体 可以将对图形对象的 ...
- linux sed使用(转)
sed入门详解教程 sed 是一个比较古老的,功能十分强大的用于文本处理的流编辑器,加上正则表达式的支持,可以进行大量的复杂的文本编辑操作.sed 本身是一个非常复杂的工具,有专门的书籍讲解 sed ...
- CodeForces - 767C
花了6个小时,终于成功ac...... 两边dfs,第一遍求子树和,第二遍判断有没有2*t[s]/3和t[s]/3,因为要求的节点可能是在同一条线上,同时要有2*t[s]/3和t[s]/3的情况,且2 ...
- 对CSS了解-选择器权重
<style type="text/css"> div.ui_infor p {font-size: 16px;} .ui_infor p {font-size: 14 ...
- OSI七层模型及应用
应用层:提供访问网络服务的接口.例如telnet. 表示层:提供数据格式转化服务.例如压缩和解压缩. 会话层:提供回话实体的连接服务,进行访问验证和会话管理.例如服务器验证用户登录和断点续传. 传输层 ...
- iOS自动化探索(一)WebDriverAgent安装
WebDriverAgent FaceBook推出的一款iOS移动测试框架, 支持真机和模拟器, 同时支持USB, 官方是这样介绍的: https://github.com/facebook/WebD ...
- 条款11:记得在operator=中处理自赋值的情况。
本来的版本是这样的: Widget & Widget::operator=(Widget rhs) { delete pb;//这里可能直接将rhs的pb删除了 pb = new (*rhs. ...
- Application的作用
Application可实现数据共享 例如: 一.新建一个空的工程,并新建一个App类,继承自Application public class App extends Application { pr ...
- head插件对elasticsearch 索引文档的增删改查
1.RESTful接口使用方法 为了方便直观我们使用Head插件提供的接口进行演示,实际上内部调用的RESTful接口. RESTful接口URL的格式: http://localhost:9200 ...
- CSS:Tutorial two
1.CSS Text text color, text align... Text Decoration The text-decoration property is used to set or ...