本题要求你实现一个天梯赛专属在线地图,队员输入自己学校所在地和赛场地点后,该地图应该推荐两条路线:一条是最快到达路线;一条是最短距离的路线。题目保证对任意的查询请求,地图上都至少存在一条可达路线。

输入格式:

输入在第一行给出两个正整数N(2 ≤ N ≤ 500)和M,分别为地图中所有标记地点的个数和连接地点的道路条数。随后M行,每行按如下格式给出一条道路的信息:

V1 V2 one-way length time

其中V1V2是道路的两个端点的编号(从0到N-1);如果该道路是从V1V2的单行线,则one-way为1,否则为0;length是道路的长度;time是通过该路所需要的时间。最后给出一对起点和终点的编号。

输出格式:

首先按下列格式输出最快到达的时间T和用节点编号表示的路线:

Time = T: 起点 => 节点1 => ... => 终点

然后在下一行按下列格式输出最短距离D和用节点编号表示的路线:

Distance = D: 起点 => 节点1 => ... => 终点

如果最快到达路线不唯一,则输出几条最快路线中最短的那条,题目保证这条路线是唯一的。而如果最短距离的路线不唯一,则输出途径节点数最少的那条,题目保证这条路线是唯一的。

如果这两条路线是完全一样的,则按下列格式输出:

Time = T; Distance = D: 起点 => 节点1 => ... => 终点

输入样例1:

10 15
0 1 0 1 1
8 0 0 1 1
4 8 1 1 1
5 4 0 2 3
5 9 1 1 4
0 6 0 1 1
7 3 1 1 2
8 3 1 1 2
2 5 0 2 2
2 1 1 1 1
1 5 0 1 3
1 4 0 1 1
9 7 1 1 3
3 1 0 2 5
6 3 1 2 1
5 3

输出样例1:

Time = 6: 5 => 4 => 8 => 3
Distance = 3: 5 => 1 => 3

输入样例2:

7 9
0 4 1 1 1
1 6 1 3 1
2 6 1 1 1
2 5 1 2 2
3 0 0 1 1
3 1 1 3 1
3 2 1 2 1
4 5 0 2 2
6 5 1 2 1
3 5

输出样例2:

Time = 3; Distance = 4: 3 => 2 => 5

解题思路:当时建图的时候把距离搞成了点的距离,和城市间紧急救援搞混了,看了一晚上自己的代码都没看出来,最后请教了Bob才知道,大佬的博客https://www.cnblogs.com/BobHuang/
菜鸡的成长史 ^_^
代码有点乱等以后来改进
 #include <bits/stdc++.h>
using namespace std;
const int N=,INF=0x3f3f3f3f;
int n,m;
struct edg
{
int B,J,S;
}E1,E2; //存边的信息,因为这个一条边有3个信息
vector<edg>G[N],T[N];
int dis[N],pre[N],vis[N],in[N],num[N],out[N];
int diss[N],sum[N];
struct Node
{
int B,J;
bool operator <(const Node&x)const{
return x.J<J;
}
}p,q;
void printff(vector<int> vec)
{
int flag=;
for(int i=vec.size()-;i>=;i--)
{
if(flag) cout << " => ";
cout << vec[i],flag=;
}
cout << endl;
}
int judge(vector<int>vec,vector<int>vec1)
{
for(int i=;i<vec.size();i++)
if(vec[i]!=vec1[i]) return ; //不相等就退出
return ;
}
void dij1(int start)
{
priority_queue<Node> que;
for(int i=;i<=N-;i++) dis[i]=INF,pre[i]=-,vis[i]=;
que.push({start,}),dis[start]=,num[start]=;
while(!que.empty())
{
p=que.top(),que.pop();
int u=p.B,v,w,z;
if(vis[u]) continue;
vis[u]=;
for(auto X:G[u])
{
v=X.B,w=X.J,z=;
if(dis[v]>w+p.J)
dis[v]=w+p.J,pre[v]=u,num[v]=num[u]+,q.B=v,q.J=dis[v],que.push(q);
else if(dis[v]==w+p.J)
{
if(num[v]>num[u]+) //节点数取小的
num[v]=num[u]+,pre[v]=u;
}
}
}
}
void dij2(int start) //时间加距离
{
priority_queue<Node> que;
for(int i=;i<=N-;i++) pre[i]=-,vis[i]=,sum[i]=INF,diss[i]=;
que.push({start,}),diss[start]=,sum[start]=; //自己到自己的距离和时间都为0
while(!que.empty())
{
p=que.top(),que.pop();
int u=p.B,v,w,z;
if(vis[u]) continue;
vis[u]=;
for(auto X:G[u])
{
v=X.B,w=X.J,z=X.S; //压入的是时间
if(sum[v]>z+p.J)
sum[v]=z+p.J,pre[v]=u,diss[v]=diss[u]+w,q.B=v,q.J=sum[v],que.push(q);
else if(sum[v]==z+p.J)
{
if(diss[v]>diss[u]+w) //节点数取小的
diss[v]=diss[u]+w,pre[v]=u;
}
}
}
} int main()
{
ios::sync_with_stdio(false);
cin>>n>>m;
for(int i=,d1,d2,d3,d4,d5;i<m;i++)
{
cin>>d1>>d2>>d3>>d4>>d5;
G[d1].push_back({d2,d4,d5}); //G 最短中最快
if(!d3) //双行线
{
G[d2].push_back({d1,d4,d5});
}
}
vector<int> vec,vec1;
int start,ending;
cin>>start>>ending;
dij2(start); //时间+距离
int pos=ending;
while(pos!=-) vec.push_back(pos),pos=pre[pos]; //vec为时间的
dij1(start); //距离+节点
pos=ending;
while(pos!=-) vec1.push_back(pos),pos=pre[pos];
if(vec.size()!=vec1.size())
{
cout << "Time = " << sum[ending] <<": ";
printff(vec);
cout << "Distance = " << dis[ending] <<": ";
printff(vec1);
}
else
{
int zhi=judge(vec,vec1); //0不相等 1相等
if(zhi==)
cout<<"Time = "<<sum[ending]<<"; "<<"Distance = "<<dis[ending]<<": ",printff(vec);
else
{
cout << "Time = " << sum[ending] <<": ";
printff(vec);
cout << "Distance = " << dis[ending] <<": ";
printff(vec1);
}
}
return ;
}

PTA天梯地图的更多相关文章

  1. pta 天梯地图 (Dijkstra)

    本题要求你实现一个天梯赛专属在线地图,队员输入自己学校所在地和赛场地点后,该地图应该推荐两条路线:一条是最快到达路线:一条是最短距离的路线.题目保证对任意的查询请求,地图上都至少存在一条可达路线. 输 ...

  2. PTA天梯 L3-007 天梯地图

    L3-007 天梯地图 题目: 本题要求你实现一个天梯赛专属在线地图,队员输入自己学校所在地和赛场地点后,该地图应该推荐两条路线:一条是最快到达路线:一条是最短距离的路线.题目保证对任意的查询请求,地 ...

  3. L3-007. 天梯地图

    L3-007. 天梯地图 题目链接:https://www.patest.cn/contests/gplt/L3-007 Dijstra 这题是Dijstra的变形,麻烦的是两种最短路的相同距离时的选 ...

  4. CCCC L2-001 紧急救援 floyd改的dijkstra模板 (记录路径) L3 天梯地图

    https://www.patest.cn/contests/gplt/L2-001 题解:求最短路的条数,并输出点的权值最大的路径,用priority_queue会wa两个点,原因不明. 于是又学了 ...

  5. pat 团体天梯赛 L3-007. 天梯地图

    L3-007. 天梯地图 时间限制 300 ms 内存限制 65536 kB 代码长度限制 8000 B 判题程序 Standard 作者 陈越 本题要求你实现一个天梯赛专属在线地图,队员输入自己学校 ...

  6. PAT天梯赛练习题——L3-007. 天梯地图(多边权SPFA)

    L3-007. 天梯地图 时间限制 300 ms 内存限制 65536 kB 代码长度限制 8000 B 判题程序 Standard 作者 陈越 本题要求你实现一个天梯赛专属在线地图,队员输入自己学校 ...

  7. pta l3-7(天梯地图)

    题目链接:https://pintia.cn/problem-sets/994805046380707840/problems/994805051153825792 题意:给定n个地点,m条边以及边的 ...

  8. PAT L3-007 天梯地图

    https://pintia.cn/problem-sets/994805046380707840/problems/994805051153825792 本题要求你实现一个天梯赛专属在线地图,队员输 ...

  9. L3-007 天梯地图 (30 分) dijkstra

    本题要求你实现一个天梯赛专属在线地图,队员输入自己学校所在地和赛场地点后,该地图应该推荐两条路线:一条是最快到达路线:一条是最短距离的路线.题目保证对任意的查询请求,地图上都至少存在一条可达路线. 输 ...

随机推荐

  1. 【C#】C#线程_基元线程的同步构造

    目录结构: contents structure [+] 简介 为什么需要使用线程同步 线程同步的缺点 基元线程同步 什么是基元线程 基元用户模式构造和内核模式构造的比较 用户模式构造 易变构造(Vo ...

  2. PHP事件机制

    先用 3W1H(who what why how) 分析法的思路来解释一下 事件机制, 更重要的是, 这个有什么用. 正常的程序执行, 或者说人的思维趋势, 都是按照 时间线性串行 的, 保持 连续性 ...

  3. spring 整合junit进行测试

    如果想让junit和spring容器环境无缝对接的话,可以使用如下方式: import com.jd.ptest.service.ICronService; import org.junit.Test ...

  4. Canvas入门到高级详解(中)

    三. canvas 进阶 3.1 Canvas 颜色样式和阴影 3.1.1 设置填充和描边的颜色(掌握) fillStyle : 设置或返回用于填充绘画的颜色 strokeStyle: 设置或返回用于 ...

  5. FastDFS常用命令

    1.启动FastDFS tracker: /usr/local/bin/fdfs_trackered %FastDFS%/tracker.conf storage: /usr/local/bin/fd ...

  6. mybatis-generator 自动生成查询Vo

    package com.witwicky.plugins; import org.mybatis.generator.api.GeneratedJavaFile; import org.mybatis ...

  7. Android跳转到应用商店的APP详情页面,以及 Google GMS 各个apk的包

    转自:http://www.jianshu.com/p/a4a806567368 需求: 从App内部点击按钮或链接,跳转到应用商店的某个APP的详情页面.让用户 下载 或 评论. 实现: /** * ...

  8. ambari 安装HDP3.0.1后,启动服务的问题记录

    HDP的ambari集成安装工具真的是比ClouderaManager差上那么一点儿,不说安装的时候就麻烦,即使软件安装包已成功安装,也不意味着可以正常使用了,启动HDP集群过程中还会有不少的错误! ...

  9. ABBYY PDF Transformer+ 给你好看

    ABBYY PDF Transformer+是一个新的.全面的巧妙解决PDF文档的工具,它将泰比的光学字符识别(OCR)技术和Adobe®PDF技术完美结合,以确保实现便捷地处理任何类型的PDF文件, ...

  10. MySQL-监控告警系统

    开源地址: https://github.com/ycg/mysql_web QQ: 779647966 Email: ycg166911@163.com 利用python的flask进行后台开发,前 ...