PTA 旅游规划(25 分)
7-10 旅游规划(25 分)
有了一张自驾旅游路线图,你会知道城市间的高速公路长度、以及该公路要收取的过路费。现在需要你写一个程序,帮助前来咨询的游客找一条出发地和目的地之间的最短路径。如果有若干条路径都是最短的,那么需要输出最便宜的一条路径。
输入格式:
输入说明:输入数据的第1行给出4个正整数N、M、S、D,其中N(2≤N≤500)是城市的个数,顺便假设城市的编号为0~(N−1);M是高速公路的条数;S是出发地的城市编号;D是目的地的城市编号。随后的M行中,每行给出一条高速公路的信息,分别是:城市1、城市2、高速公路长度、收费额,中间用空格分开,数字均为整数且不超过500。输入保证解的存在。
输出格式:
在一行里输出路径的长度和收费总额,数字间以空格分隔,输出结尾不能有多余空格。
输入样例:
4 5 0 3
0 1 1 20
1 3 2 30
0 3 4 10
0 2 2 20
2 3 1 20
#include<bits/stdc++.h>
using namespace std;
#define maxn 0x7fffffff
int mat[505][505],vis[505],pay[505][505];
/*
mat 是图的邻接矩阵表示,vis是标记数组 , pay 是花费的邻接矩阵表示
*/
int dis[505],cost[505],n,m,path[505]; //最短路 + 路径输出
//n 是点的个数 标记为 0 ~ n-1 ,
//dis 最短路记录数组,cost 最小花费记录数组,path 路径记录数组
void dijkstra(int s) //修改后的最短路算法,+path 记录 和 花费计算
{
int i,j;
memset(vis,0,sizeof(vis));//清空标记数组
for(i=0;i<n;i++)
{
/*
用mat临接矩阵的值初始化dis 的值
用pay临接矩阵的值初始化cost 的值
*/
dis[i]=mat[s][i];
cost[i]=pay[s][i];
if(dis[i]!=maxn) //无穷大代表此路不通 path[i] =-1,否则就在路径加入这个点
path[i]=s;
else path[i]=-1;
}
vis[s]=1;//起始点标记
dis[s]=0;//自己到自己的花费cost = 0
cost[s]=0;
for(i=1;i<n;i++)
{
int k=s,u=maxn;
/*
找出到s距离最短&没标记的点,作为中转点更新dis值
*/
for(j=0;j<n;j++)
{
if(!vis[j]&&dis[j]<u)
{
u=dis[j];
k=j;
}
}
vis[k]=1;//标记这个点
for(j=0;j<n;j++)
{
if(!vis[j]&&mat[k][j]!=maxn)
{
/*
用这个点更新dis值,cost 和 dis同步更新,参数值相同
如果把k作为中转点成功缩减了dis值,就让k点加入path路径里
*/
if(dis[j]>dis[k]+mat[k][j])
{
dis[j]=dis[k]+mat[k][j];
cost[j]=cost[k]+pay[k][j];
path[j]=k;
}
/*
最短路径dis相同的话,选择花费最少的,最小cost
*/
else if(dis[j]==dis[k]+mat[k][j])
{
/*
如果这个花费更加优,那么把这个点加入,更新最优秀的路径
最后path里面记录的是最优路径
*/
if(cost[j]>cost[k]+pay[k][j])
{
cost[j]=cost[k]+pay[k][j];
path[j]=k;
}
}
}
}
}
}
void print(int s,int t)
{
stack<int>q;
/*
从path里溯源t = path[t],返回上一个和t联通的路径,由后往前,把s~t路径放入队列里面,然后输出
*/
while(t!=s)
{
q.push(t);
t=path[t];
}
q.push(t);
while(!q.empty())
{
cout<<q.top()<<" ";
q.pop();
}
}
int main()
{
int s,t,a,b,d,w,i,j;
cin>>n>>m>>s>>t;
for(i=0;i<n;i++)
for(j=0;j<n;j++)
mat[i][j]=pay[i][j]=maxn;
/*
初始化数组,让距离邻接矩阵数组值 = 无穷大,花费邻接矩阵的值 = 无穷大
这个计算方式对无向图和有向图同样适用,只需要部分修改
*/
for(i=0;i<m;i++)
{
cin>>a>>b>>d>>w;
if(mat[a][b]>d)
{
mat[a][b]=mat[b][a]=d;
pay[a][b]=pay[b][a]=w;
}
else if(mat[a][b]==d)
{
if(pay[a][b]>w)
pay[a][b]=pay[b][a]=w;
} // 输入进行处理,最短路
}
dijkstra(s); // 寻找从 s 开始 单源最短路
// print(s,t);// 输出路径, S 到 T 的路径
cout<<dis[t]<<" "<<cost[t]<<endl; // dist 指的是 距离 dis[t] 指的是花费
return 0;
}
PTA 旅游规划(25 分)的更多相关文章
- PTA 07-图6 旅游规划 (25分)
题目地址 https://pta.patest.cn/pta/test/15/exam/4/question/717 5-9 旅游规划 (25分) 有了一张自驾旅游路线图,你会知道城市间的高速公路 ...
- PAT 07-图6 旅游规划 (25分)
有了一张自驾旅游路线图,你会知道城市间的高速公路长度.以及该公路要收取的过路费.现在需要你写一个程序,帮助前来咨询的游客找一条出发地和目的地之间的最短路径.如果有若干条路径都是最短的,那么需要输出最便 ...
- 【(图) 旅游规划 (25 分)】【Dijkstra算法】
#include<iostream> #include<cstdio> #include<algorithm> #include<cstring> us ...
- PTA 列车调度 (25分)
PTA 列车调度 (25分) [程序实现] #include<bits/stdc++.h> using namespace std; int main(){ int num,n; cin& ...
- PTA 朋友圈 (25 分) 代码详解 (并查集)
1.题目要求: 某学校有N个学生,形成M个俱乐部.每个俱乐部里的学生有着一定相似的兴趣爱好,形成一个朋友圈.一个学生可以同时属于若干个不同的俱乐部.根据"我的朋友的朋友也是我的朋友" ...
- PTA 5-12 排序 (25分)
给定NN个(长整型范围内的)整数,要求输出从小到大排序后的结果. 本题旨在测试各种不同的排序算法在各种数据情况下的表现.各组测试数据特点如下: 数据1:只有1个元素: 数据2:11个不相同的整数,测试 ...
- pat06-图5. 旅游规划(25)
06-图5. 旅游规划(25) 时间限制 400 ms 内存限制 65536 kB 代码长度限制 8000 B 判题程序 Standard 有了一张自驾旅游路线图,你会知道城市间的高速公路长度.以及该 ...
- PTA 7-10(图) 旅游规划 最短路问题
7-10(图) 旅游规划 (25 分) 有了一张自驾旅游路线图,你会知道城市间的高速公路长度.以及该公路要收取的过路费.现在需要你写一个程序,帮助前来咨询的游客找一条出发地和目的地之间的最短路径.如果 ...
- PTA 11-散列3 QQ帐户的申请与登陆 (25分)
题目地址 https://pta.patest.cn/pta/test/15/exam/4/question/723 5-15 QQ帐户的申请与登陆 (25分) 实现QQ新帐户申请和老帐户登陆的简 ...
随机推荐
- php的借用其他网站的页面覆盖Logo的技巧
php的借用其他网站的页面覆盖Logo的技巧, <body> <div id="red_f"></div> <div class=&quo ...
- 【原创】公司各个阶段 CTO 需要做什么?(上篇)
CTO 是企业内技术最高负责人,对企业的发展起到至关重要的作用.但随着公司的不断发展,CTO 的工作重心也会不断变化.只有在正确的阶段做正确的事,才能更好地为公司做出贡献.我是空中金融 CTO ,TG ...
- django 配置URLconf和获取值
django中正确配置url匹配找到视图: 1 在项目下的settings.py中ROOT_URLCONF = "项目名.urls" 表示 前台发来请求会先去项目下的test3/u ...
- 百度资深架构师带你深入浅出一致性Hash原理
一.前言 在解决分布式系统中负载均衡的问题时候可以使用Hash算法让固定的一部分请求落到同一台服务器上,这样每台服务器固定处理一部分请求(并维护这些请求的信息),起到负载均衡的作用. 但是普通的余数h ...
- [POI2008]BLO-Blockade - Tarjan,割点
Description 给定一张无向图,求每个点被封锁(删去与其相连的边)之后有多少个有序点对(x,y)(x!=y,1<=x,y<=n)满足x无法到达y. Input&Output ...
- centos系统php5.6版本安装gd扩展库
由于项目需要显示验证码登录系统,所以这里需要开启php的gd扩展 这边提供安装php5.6的yum方法扩展自选.# rpm -Uvh http://ftp.iij.ad.jp/pub/linux/fe ...
- Python/ selectors模块及队列
Python/selectors模块及队列 selectors模块是可以实现IO多路复用机制: 它具有根据平台选出最佳的IO多路机制,比如在win的系统上他默认的是select模式而在linux上它默 ...
- 一 Unicode和UTF-8的异同
下面就是我的笔记,主要用来整理自己的思路.但是,我尽量试图写得通俗易懂,希望能对其他朋友有用.毕竟,字符编码是计算机技术的基石,想要熟练使用计算机,就必须懂得一点字符编码的知识.1. ASCII码我们 ...
- Batch训练的反向传播过程
Batch训练的反向传播过程 本文试图通过Softmax理解Batch训练的反向传播过程 采用的网络包含一层全连接和一层softmax,具体网络如下图所示: 交叉熵成本函数: \[L = - \fra ...
- kafka知识体系
最近一直在整理kafka相关资料,以构建自己的知识体系. 主要分为五大方面: Kafka设计与原理分析 Kafka配置分析 Kafka运维手册 Kafka编程开发 kafka源码分析