1072 Gas Station (30)(30 分)
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 (<= 10^3^), 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 D~S~, 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
中途有个判断条件写错了总是有个点 不对,好蠢,station之间的距离可以可以超过range范围,判断的时候只需要判断house,啊。。。好蠢。n个house 1~n,station 1~m加到n后面,总的进行最短路
dijkstra,然后判断,取优。 代码:
#include <iostream>
#include <cstring>
#include <cstdio>
#include <algorithm>
#include <map>
#define inf 0x3f3f3f3f
#define MAX 2020
using namespace std;
int n,m,k,ds,d,mp[MAX][MAX],dis[MAX];
int vis[MAX];
char s1[],s2[];
int id,ma,sum;
int change(char *temp) {
int su = ,i = ,j = ;
if(temp[] == 'G') {
i ++;
j += n;
}
while(temp[i]) {
su = su * + temp[i ++] - '';
}
return su + j;
}
void dijkstra() {
for(int i = n + ;i <= n + m;i ++) {
memset(vis,,sizeof(vis));
int tsum = ,tma = ,flag = ;
for(int j = ;j <= n + m;j ++) {
dis[j] = mp[i][j];
}
while() {
int t = -,mi = inf;
for(int j = ;j <= n + m;j ++) {
if(!vis[j] && dis[j] < mi){
t = j,mi = dis[j];
}
}
if(t == -)break;
if(t <= n) {
if(dis[t] > ds || !tsum && dis[t] < ma) {
flag = ;
break;
}
else if(!tsum)tma = dis[t];
tsum += dis[t];
}
vis[t] = ;
for(int j = ;j <= n + m;j ++) {
if(vis[j] || mp[t][j] == inf)continue;
if(dis[t] + mp[t][j] < dis[j])dis[j] = dis[t] + mp[t][j];
}
}
if(!flag)continue;
if(tma > ma) {
id = i;
ma = tma;
sum = tsum;
}
else if(tsum < sum) {
sum = tsum;
id = i;
}
}
}
int main() {
scanf("%d%d%d%d",&n,&m,&k,&ds);
for(int i = ;i <= n + m;i ++) {
for(int j = ;j <= n + m;j ++) {
mp[i][j] = inf;
}
mp[i][i] = ;
}
for(int i = ;i < k;i ++) {
scanf("%s%s%d",s1,s2,&d);
int x = change(s1),y = change(s2);
mp[x][y] = mp[y][x] = d;
}
dijkstra();
if(!id)printf("No Solution");
else printf("G%d\n%.1f %.1f",id - n,(double)ma,(double)sum / (double)n);
}
1072 Gas Station (30)(30 分)的更多相关文章
- 1072 Gas Station (30 分)(最短路径)
#include<bits/stdc++.h> using namespace std; ; int n,m,k,Ds; int mp[N][N]; int dis[N]; int vis ...
- 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 甲级 1072. Gas Station (30)
1072. Gas Station (30) 时间限制 200 ms 内存限制 65536 kB 代码长度限制 16000 B 判题程序 Standard 作者 CHEN, Yue A gas sta ...
- 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[图论][难]
1072 Gas Station (30)(30 分) A gas station has to be built at such a location that the minimum distan ...
- 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) 多源最短路
A gas station has to be built at such a location that the minimum distance between the station and a ...
- 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 an ...
随机推荐
- 【ORACLE】ORA-27102: out of memory报错的处理
************************************************************************ ****原文:blog.csdn.net/clark_ ...
- Orcad CIS怎么批量修改字体大小
选中DSN,右键,design properties, schematic design,选择design properties.
- 自己定义ProgressDialog载入图片
使用系统载入框 mDialog = new ProgressDialog(this); mDialog.setCancelable(true);//能否够被取消 mDialog.setMessage( ...
- 【WPF】ComboBox:根据绑定选取、设置固定集合中的值
问题场景 我有一个对象,里面有一个属性叫Limit,int类型.虽然int可取的范围很大,我想要在用户界面上限制Limit可取的值,暂且限制为5.10.15.20. 所以ComboBox绑定不是绑定常 ...
- 前端要给力之:语句在JavaScript中的值
文件夹 文件夹 问题是语句有值吗 那么说你骗我咯 有啥米用呢 研究这个是不是闲得那个啥疼 ES5ES6有什么差异呢 结论是ES6是改了规则但更合理 最后不不过if语句 这两天在写语言精髓那本书的第三版 ...
- loadrunner动态从mysql取值 [需要下载跟数据库服务器一致的dll,32位或64位]
loadrunner中有参数化从数据库中取值,但是只是静态的,对于一些要实时取值的数据就game over了,比如取短信验证码,因为MySQL中有一个libmysql.dll,里面提供了可以操作数据库 ...
- EasyPlayer RTSP Android安卓播放器实现视频源快速切换
EasyPlayer现在支持多视频源快速切换了,我们介绍一下是如何实现的. 这个需求通常应用在一个客户端需要查看多个视频源的情况,比如多个监控场景轮播. 由于EasyPlayer的播放端已经放在Fra ...
- python 搜集参数的共有项和所有项
搜集共性项和所有项 ###搜集共有参数值 def intersect(*args): res=[] for x in args[0]: for other in args[1:]: if x not ...
- centos 安装postgresql 完整版
按步骤 执行命令即可: yum install https://download.postgresql.org/pub/repos/yum/10/redhat/rhel-7-x86_64/pgdg-c ...
- 在RedHat Linux系统中安装和配置snmp服务
检查系统是否安装snmp服务 # rpm -qa|grep snmp net-snmp-5.3.2.2-17.el5 net-snmp-perl-5.3.2.2-17.el5 net-snmp-dev ...