思路:单源最短路末班就好了,字符串映射成数字处理。
AC代码
//#define LOCAL
#include <stdio.h>
#include <string.h>
#include <algorithm>
#include <queue>
#include <map>
#include <vector>
#include <string>
using namespace std;
#define inf 0x3f3f3f3f
const int maxn = 200;
map<string, int> ha;
int id, st, ed;
int n, k;
int hap[maxn];
char names[maxn][50];
int getId(string s) {
if(!ha.count(s)) {
ha[s] = id++;
}
return ha[s];
}
struct Edge {
int from, to, dist;
Edge(int u, int v, int d):from(u),to(v),dist(d) {}
};
vector<Edge> edges;
vector<int> G[maxn];
bool done[maxn];
int d[maxn], hp[maxn], pt[maxn], routes[maxn]; //Best
int p[maxn];
void init() {
ha.clear();
id = 0;
for(int i = 0; i < maxn; i++) G[i].clear();
edges.clear();
}
void addEdge(int from, int to, int dist) {
edges.push_back(Edge(from, to, dist));
int m = edges.size();
G[from].push_back(m-1);
}
struct HeapNode{
int d, u;
HeapNode(int d, int u):d(d), u(u){
}
bool operator < (const HeapNode& rhs) const {
return d > rhs.d;
}
};
//距离小,开心多,平均大
void dijkstra(int s) {
memset(done, 0, sizeof(done));
priority_queue<HeapNode> Q;
for(int i = 0; i < n; i++) {
d[i] = inf;
hp[i] = -inf;
pt[i] = inf;
}
d[s] = hp[s] = pt[s] = 0;
routes[s] = 1;
Q.push(HeapNode(0, s));
while(!Q.empty()) {
HeapNode x = Q.top(); Q.pop();
int u = x.u;
if(done[u]) continue;
done[u] = true;
for(int i = 0; i < G[u].size(); i++) {
Edge& e = edges[G[u][i]];
bool update = false;
if(d[e.to] > d[u] + e.dist) {
routes[e.to] = routes[u];
update = true;
} else if(d[e.to] == d[u] + e.dist) {
routes[e.to] += routes[u];
if(hp[e.to] < hp[u] + hap[e.to]) {
update = true;
} else if(hp[e.to] == hp[u] + hap[e.to]) {
if(pt[e.to] > pt[u] + 1) {
update = true;
}
}
}
if(update) {
d[e.to] = d[u] + e.dist;
p[e.to] = u;
hp[e.to] = hp[u] + hap[e.to];
pt[e.to] = pt[u] + 1;
Q.push(HeapNode(d[e.to], e.to));
}
}
}
}
void print(int u) {
if(u == 0) {
printf("%s", names[0]);
return;
} else {
print(p[u]);
printf("->%s", names[u]);
}
}
int main() {
#ifdef LOCAL
freopen("data.in", "r", stdin);
freopen("data.out", "w", stdout);
#endif
while(scanf("%d%d%s", &n, &k, names[0]) == 3) {
init();
st = getId(names[0]);
int happy;
for(int i = 1; i < n; i++) {
scanf("%s %d", names[i], &happy);
int u = getId(names[i]);
hap[u] = happy;
}
ed = getId("ROM");
char x[50], y[50];
int u, v, cost;
for(int i = 0; i < k; i++) {
scanf("%s%s%d", x, y, &cost);
u = getId(x), v = getId(y);
//printf("%d %d\n", u, v);
addEdge(u, v, cost);
addEdge(v, u, cost);
}
dijkstra(0);
printf("%d %d %d %d\n", routes[ed], d[ed], hp[ed], (int)(hp[ed]/pt[ed]));
print(ed);
printf("\n");
}
return 0;
}
如有不当之处欢迎指出!
PAT All Roads Lead to Rome 单源最短路的更多相关文章
-
PAT 1087 All Roads Lead to Rome[图论][迪杰斯特拉+dfs]
1087 All Roads Lead to Rome (30)(30 分) Indeed there are many different tourist routes from our city ...
-
PAT 1087 All Roads Lead to Rome
PAT 1087 All Roads Lead to Rome 题目: Indeed there are many different tourist routes from our city to ...
-
PAT甲级1087. All Roads Lead to Rome
PAT甲级1087. All Roads Lead to Rome 题意: 确实有从我们这个城市到罗马的不同的旅游线路.您应该以最低的成本找到您的客户的路线,同时获得最大的幸福. 输入规格: 每个输入 ...
-
PAT 甲级 1087 All Roads Lead to Rome(SPFA+DP)
题目链接 All Roads Lead to Rome 题目大意:求符合题意(三关键字)的最短路.并且算出路程最短的路径有几条. 思路:求最短路并不难,SPFA即可,关键是求总路程最短的路径条数. 我 ...
-
pat1087. All Roads Lead to Rome (30)
1087. All Roads Lead to Rome (30) 时间限制 200 ms 内存限制 65536 kB 代码长度限制 16000 B 判题程序 Standard 作者 CHEN, Yu ...
-
PAT_A1087#All Roads Lead to Rome
Source: PAT A1087 All Roads Lead to Rome (30 分) Description: Indeed there are many different tourist ...
-
[图的遍历&;多标准] 1087. All Roads Lead to Rome (30)
1087. All Roads Lead to Rome (30) Indeed there are many different tourist routes from our city to Ro ...
-
PAT1087. All Roads Lead to Rome
PAT1087. All Roads Lead to Rome 题目大意 给定一个图的边权和点权, 求边权最小的路径; 若边权相同, 求点权最大; 若点权相同, 则求平均点权最大. 思路 先通过 Di ...
-
最短路模板(Dijkstra &; Dijkstra算法+堆优化 &; bellman_ford &; 单源最短路SPFA)
关于几个的区别和联系:http://www.cnblogs.com/zswbky/p/5432353.html d.每组的第一行是三个整数T,S和D,表示有T条路,和草儿家相邻的城市的有S个(草儿家到 ...
随机推荐
-
手持设备点击响应速度,鼠标事件与touch事件的那些事
前言 现在一直在做移动端的开发,这次将单页应用的网页内嵌入了app,于是老大反映了一个问题:app应用点击响应慢!我开始不以为然,于是拿着网页版的试了试,好像确实有一定延迟,于是开始了研究,最后选择了 ...
-
深入理解Web标准(网站标准)
深入理解Web标准(网站标准) 我觉得一名Web前端应该好好理解Web标准到底是什么,为什么要在我们的实际实践中遵循Web标准. 什么是Web标准.百度百科的解释是: WEB标准不是某一个标准,而 ...
-
[IOS]cocoapos 两个ruby源的对比
最近需要使用一些动态类库,cocoapods比较好用,能帮助管理这些类库,百度一下也能找到很多cocoapods配置方法,这里不赘述,我想要讲的是在配置的时候一般都会推荐这样做 $ gem sourc ...
-
动态加载jQuery
success: function(data){ for(var i in data){ $('.x-details>ul:eq(0)').append("<li>&quo ...
-
svn 在linux 下的一些常用命令
最近在Linux系统下玩一些svn的东西,感觉脑袋很乱, 于是整理了一下一些初学者必须弄明白的基本命令: 1. svn --version: 查看Linux系统下的svn client版本. Clie ...
-
编写爬虫程序的神器 - Groovy + Jsoup + Sublime
写过很多个爬虫小程序了,之前几次主要用C# + Html Agility Pack来完成工作.由于.NET BCL只提供了"底层"的HttpWebRequest和"中层& ...
-
oracle分析函数 之分组累加求和
select s.slice_date_to ,s.made_id ,sum(s.steup_count)over(partition by s.made_id order by s.slice_da ...
-
offsetXXX和scollXXX的一些操作
<!doctype html><html><head><meta charset="utf-8"><title>offs ...
-
Apache和PHP环境配置
最近闲来想学习一下PHP. 工欲善其事,必先利其器.我的PHP环境配置了三遍,才安装成功. 下面就分享一下我的安装经验. 1.Apache2.4,PHP5.6,MySql5.6这些都是从官网下载的. ...
-
Python-接口自动化(八)
unittest单元测试框架(八) (九)unittest 1.基本概念 python自带的unittest单元测试框架不仅可以适用于单元测试,也适用于WEB自动化测试用例的开发与执行,uint ...