PAT Advanced 1072 Gas Station (30) [Dijkstra算法]
题目
A gas station has to be built at such a location that the minimum distance between the station and any of the residential housing is as far away as possible. However it must guarantee that all the houses are in its service range. Now given the map of the city and several candidate locations for the gas station, you are supposed to give the best recommendation. If there are more than one solution, output the one with the smallest average distance to all the houses. If such a solution is still not unique, output the one with the smallest index number.
Input Specification:
Each input file contains one test case. For each case, the first line contains 4 positive integers: N (<= 103), the total number of houses; M (<= 10), the total number of the candidate locations for the gas stations; K (<= 10^4), the number of roads connecting the houses and the gas stations; and DS, the maximum service range of the gas station. It is hence assumed that all the houses are numbered from 1 to N, and all the candidate locations are numbered from G1 to GM. Then K lines follow, each describes a road in the format
P1 P2 Dist
where P1 and P2 are the two ends of a road which can be either house numbers or gas station numbers, and Dist is the integer length of the road.
Output Specification:
For each test case, print in the first line the index number of the best location. In the next line, print the minimum and the average distances between the solution and all the houses. The numbers in a line must be separated by a space and be accurate up to 1 decimal place. If the solution does not exist, simply output “No Solution”.
Sample Input 1:
4 3 11 5
1 2 2
1 4 2
1 G1 4
1 G2 3
2 3 2
2 G2 1
3 4 2
3 G3 2
4 G1 3
G2 G1 1
G3 G2 2
Sample Output 1:
G1
2.0 3.3
Sample Input 2:
2 1 2 10
1 G1 9
2 G1 20
Sample Output 2:
No Solution
题意
加油站选址,有m个位置可供选择,取离城市中最近的住房距离最远的位置,若有多个满足条件的位置,取到所有住房的平均距离最短的位置
题目分析
已知图的n个顶点、边、边权,提供另外m个顶点位置,寻找到这n个顶点最近顶点的距离最短的位置,若有多个,取到n个顶点平均距离最短的位置,打印该位置距n个顶点最近的点的距离,和到n个顶点的平均距离,精确到小数点后1位
解题思路
1 dijkstra求出每个供选择顶点到n个顶点的最近距离mindis,取所有最近距离中距离最远的位置,并记录最小距离和平均距离
易错点
1 每次个供选择的顶点位置dijkstra计算最短距离时,需要重置已访问标记数组
Code
#include <iostream>
#include <vector>
#include <algorithm>
#include <string>
using namespace std;
const int maxn=1020, INF=999999999;
int n,m,k,ds,g[maxn][maxn];
int dist[maxn],col[maxn];
void dijkstra(int u) {
fill(dist,dist+1020,INF);
fill(col,col+1020,0); //每次统计需要重置col已访问标记数组
dist[u]=0;
for(int i=1; i<=n+m; i++) {
int min=-1,mind=INF;
for(int j=1; j<=n+m; j++) {
if(col[j]==0&&dist[j]<mind) {
mind=dist[j];
min = j;
}
}
if(min==-1)break;
col[min]=1;
for(int j=1; j<=n+m; j++) {
if(g[min][j]==0||col[j]==1)continue;
if(dist[j]>dist[min]+g[min][j]) { //==说明路径相同但是顶点更多,则平均值更小 ||dist[j]==dist[min]+g[min][j]
dist[j]=dist[min]+g[min][j];
}
}
}
}
int main(int argc,char * argv[]) {
scanf("%d %d %d %d",&n,&m,&k,&ds);
string a,b;
int ia,ib,d;
for(int i=0; i<k; i++) {
cin>>a>>b>>d;
if(a[0]=='G')ia=n+stoi(a.substr(1));
else ia=stoi(a);
if(b[0]=='G')ib=n+stoi(b.substr(1));
else ib=stoi(b);
g[ia][ib]=g[ib][ia]=d; //边权
}
// 求每个位置的最短路径
int ansid=-1; // dist[n]中最小值对应的顶点--离加油站最近的顶点
double ansdis=-1,ansavgd=INF; // dist[n]中最小值 --- 距加油站最近的顶点的距离
for(int i=1; i<=m; i++) {
dijkstra(n+i);
//求平均值
double avgd=0,mindis=INF; // avgd 边权平均值; mindis加油站到所有顶点距离的最小值
for(int j=1; j<=n; j++) {
if(dist[j]>ds) {
mindis=-1;
break;
}
if(dist[j]<mindis)mindis=dist[j]; //取所有位置中离城市中最近的住宅最远的加油站位置
avgd+=(1.0*dist[j]); //记录边权
}
if(mindis==-1)continue;
avgd=avgd/n; //距离平均值
if(mindis>ansdis) {
//取离加油站最近城市最远的位置 若相等 取编号最小者
//更新路径信息
ansid=i;
ansdis=mindis;
ansavgd=avgd;
} else if(mindis==ansdis&&avgd<ansavgd) {
ansid=i;
ansavgd=avgd;
}
}
// 打印
if(ansid == -1)
printf("No Solution");
else
printf("G%d\n%.1f %.1f", ansid, ansdis, ansavgd);
return 0;
}

PAT Advanced 1072 Gas Station (30) [Dijkstra算法]的更多相关文章
- pat 甲级 1072. Gas Station (30)
1072. Gas Station (30) 时间限制 200 ms 内存限制 65536 kB 代码长度限制 16000 B 判题程序 Standard 作者 CHEN, Yue A gas sta ...
- PAT 甲级 1072 Gas Station (30 分)(dijstra)
1072 Gas Station (30 分) A gas station has to be built at such a location that the minimum distance ...
- PAT Advanced 1030 Travel Plan (30) [Dijkstra算法 + DFS,最短路径,边权]
题目 A traveler's map gives the distances between cities along the highways, together with the cost of ...
- PAT甲题题解-1072. Gas Station (30)-dijkstra最短路
题意:从m个加油站里面选取1个站点,使得其离住宅的最近距离mindis尽可能地远,并且离所有住宅的距离都在服务范围ds之内.如果有很多相同mindis的加油站,输出距所有住宅平均距离最小的那个.如果平 ...
- PAT Advanced 1111 Online Map (30) [Dijkstra算法 + DFS]
题目 Input our current position and a destination, an online map can recommend several paths. Now your ...
- 1072. Gas Station (30)【最短路dijkstra】——PAT (Advanced Level) Practise
题目信息 1072. Gas Station (30) 时间限制200 ms 内存限制65536 kB 代码长度限制16000 B A gas station has to be built at s ...
- PAT 1072. Gas Station (30)
A gas station has to be built at such a location that the minimum distance between the station and a ...
- 1072. Gas Station (30)
先要求出各个加油站 最短的 与任意一房屋之间的 距离D,再在这些加油站中选出最长的D的加油站 ,该加油站 为 最优选项 (坑爹啊!).如果相同D相同 则 选离各个房屋平均距离小的,如果还是 相同,则 ...
- 1072 Gas Station (30)(30 分)
A gas station has to be built at such a location that the minimum distance between the station and a ...
随机推荐
- PaperReading20200222
CanChen ggchen@mail.ustc.edu.cn VS-GAE Motivation: With the publication of NAS101, researchers can ...
- MyBatis 学习二之简单练习巩固
1.新建一个maven项目并在pom.xml中添加依赖 2.项目架构 配置文件:SqlMapConfig.xml <?xml version="1.0" encoding ...
- Keras入门——(2)卷积神经网络CNN
前期准备工作参考:https://www.cnblogs.com/ratels/p/11144881.html 基于CNN算法利用Keras框架编写代码实现对Minst数据分类识别: from ker ...
- 富文本编辑器summernote的基本使用
summernote比较突出的优点就是能保持复制过来的东西的原有样式,并且比较流畅. 官方文档地址:https://summernote.org/getting-started 我是用到cdn引入 & ...
- Day9 - A - Apple Catching POJ - 2385
Description 有两棵APP树,编号为1,2.每一秒,这两棵APP树中的其中一棵会掉一个APP.每一秒,你可以选择在当前APP树下接APP,或者迅速移动到另外一棵APP树下接APP(移动时间可 ...
- Day2-H-非常可乐-HDU1495
大家一定觉的运动以后喝可乐是一件很惬意的事情,但是seeyou却不这么认为.因为每次当seeyou买了可乐以后,阿牛就要求和seeyou一起分享这一瓶可乐,而且一定要喝的和seeyou一样多.但see ...
- 5.8 Nginx 常用功能的配置
- Linux 内核 编译模块
背景: 由于调试内核或者由于分区大小限制,有时候内核组件不一定完全需要编进内核中. 所以,在开发中经常将内核组件编译成为模块,等到在恰当的时机加载. 概览: Linux内核模块的编译方法有两种: 1. ...
- 51nod 1445:变色DNA 最短路变形
1445 变色DNA 题目来源: TopCoder 基准时间限制:1 秒 空间限制:131072 KB 分值: 40 难度:4级算法题 收藏 关注 有一只特别的狼,它在每个夜晚会进行变色,研究发现 ...
- maze-----攻防世界
题目下载之后在linux上查看一下 发现是elf文件尝试运行一下: 要求输入正确的flag才可以,ida查看 交叉引用 对长度和开头对比,进行判断. 转到400690查看 和#进行比较,hex 是一个 ...