L3-011 直捣黄龙 (30 分)
本题是一部战争大片 —— 你需要从己方大本营出发,一路攻城略地杀到敌方大本营。首先时间就是生命,所以你必须选择合适的路径,以最快的速度占领敌方大本营。当这样的路径不唯一时,要求选择可以沿途解放最多城镇的路径。若这样的路径也不唯一,则选择可以有效杀伤最多敌军的路径。
输入格式:
输入第一行给出 2 个正整数 N(2 ≤ N ≤ 200,城镇总数)和 K(城镇间道路条数),以及己方大本营和敌方大本营的代号。随后 N-1 行,每行给出除了己方大本营外的一个城镇的代号和驻守的敌军数量,其间以空格分隔。再后面有 K 行,每行按格式城镇1 城镇2 距离
给出两个城镇之间道路的长度。这里设每个城镇(包括双方大本营)的代号是由 3 个大写英文字母组成的字符串。
输出格式:
按照题目要求找到最合适的进攻路径(题目保证速度最快、解放最多、杀伤最强的路径是唯一的),并在第一行按照格式己方大本营->城镇1->...->敌方大本营
输出。第二行顺序输出最快进攻路径的条数、最短进攻距离、歼敌总数,其间以 1 个空格分隔,行首尾不得有多余空格。
输入样例:
10 12 PAT DBY
DBY 100
PTA 20
PDS 90
PMS 40
TAP 50
ATP 200
LNN 80
LAO 30
LON 70
PAT PTA 10
PAT PMS 10
PAT ATP 20
PAT LNN 10
LNN LAO 10
LAO LON 10
LON DBY 10
PMS TAP 10
TAP DBY 10
DBY PDS 10
PDS PTA 10
DBY ATP 10
输出样例:
PAT->PTA->PDS->DBY
3 30 210
一道最短路径的题目,一遍dijkstra就可以过,就是看起来比较麻烦,要记录的东西比较多,还得把城市字符串映射到整数。
代码:
#include <iostream>
#include <cstdio>
#include <set>
#include <cstring>
#define inf 0x3f3f3f3f
using namespace std;
int n,k;
char s[],t[];
char str[][];///下标对应的城市名字
int num[];///把字符串映射的整数映射到下标
int from,to;///起点和终点下标
int en[];///城市敌军数
int mp[][];///邻接矩阵存距离
int dis[];///最短距离
int cnum[];///经过城市最多数量
int pnum[];///杀敌最多数量
int pathfrom[];///最佳路径的上一个城市编号
bool vis[];///标记是否访问过
int pathnum[];///最短路径数
inline int Hash(char *s) {///字符串到整数的映射 后面再把整数映射到0~n-1
return (s[] - 'A') * * + (s[] - 'A') * + s[] - 'A';
}
void print_path(int p) {///输出最佳路径
if(p == ) {
printf("%s",str[]);
return;
}
print_path(pathfrom[p]);
printf("->%s",str[p]);
}
int main() {
char temp[];
scanf("%d%d",&n,&k);
scanf("%s%s",s,t);
strcpy(str[],s);
for(int i = ;i < n;i ++) {
scanf("%s%d",temp,&en[i]);
num[Hash(temp)] = i;
strcpy(str[i],temp);
}
to = num[Hash(t)];
int d;
for(int i = ;i < n;i ++) {///初始化
for(int j = ;j < n;j ++) {
mp[i][j] = inf;
}
dis[i] = inf;
}
dis[] = ;
pathnum[] = ;
for(int i = ;i < k;i ++) {
scanf("%s%s%d",s,t,&d);
int a = num[Hash(s)];
int b = num[Hash(t)];
mp[a][b] = mp[b][a] = d;
}
while() {///dijkstra
int t = -,dist = inf;
for(int i = ;i < n;i ++) {
if(!vis[i] && dist > dis[i]) {
dist = dis[i];
t = i;
}
}
if(t == -) break;
vis[t] = true;
for(int i = ;i < n;i ++) {
if(vis[i] || dis[i] < dis[t] + mp[t][i]) continue;
if(dis[i] > dis[t] + mp[t][i]) {
dis[i] = dis[t] + mp[t][i];
pathfrom[i] = t;
cnum[i] = cnum[t] + ;
pnum[i] = pnum[t] + en[i];
pathnum[i] = ;///最短路径数置为0
}
else if(cnum[i] < cnum[t] + ) {
cnum[i] = cnum[t] + ;
pathfrom[i] = t;
pnum[i] = pnum[t] + en[i];
}
else if(cnum[i] == cnum[t] + && pnum[i] < pnum[t] + en[i]) {
pnum[i] = pnum[t] + en[i];
pathfrom[i] = t;
}
pathnum[i] += pathnum[t];///最短路径加上从t过来的数量
}
}
print_path(to);
printf("\n%d %d %d",pathnum[to],dis[to],pnum[to]);
}
L3-011 直捣黄龙 (30 分)的更多相关文章
- 天梯赛练习 L3-011 直捣黄龙 (30分) dijkstra + dfs
题目分析: 本题我有两种思路,一种是只依靠dijkstra算法,在dijkstra部分直接判断所有的情况,以局部最优解得到全局最优解,另一种是dijkstra + dfs,先计算出最短距离以及每个点的 ...
- pta5-9 Huffman Codes (30分)
5-9 Huffman Codes (30分) In 1953, David A. Huffman published his paper "A Method for the Const ...
- PTA 05-树9 Huffman Codes (30分)
题目地址 https://pta.patest.cn/pta/test/16/exam/4/question/671 5-9 Huffman Codes (30分) In 1953, David ...
- PTA 7-2 哈夫曼编码 (30分)
PTA 7-2 哈夫曼编码 (30分) 给定一段文字,如果我们统计出字母出现的频率,是可以根据哈夫曼算法给出一套编码,使得用此编码压缩原文可以得到最短的编码总长.然而哈夫曼编码并不是唯一的.例如对字符 ...
- PTA 07-图5 Saving James Bond - Hard Version (30分)
07-图5 Saving James Bond - Hard Version (30分) This time let us consider the situation in the movie ...
- PTA 社交网络图中结点的“重要性”计算(30 分)
7-12 社交网络图中结点的“重要性”计算(30 分) 在社交网络中,个人或单位(结点)之间通过某些关系(边)联系起来.他们受到这些关系的影响,这种影响可以理解为网络中相互连接的结点之间蔓延的一种相互 ...
- L3-015 球队“食物链” (30 分)
L3-015 球队“食物链” (30 分) 某国的足球联赛中有N支参赛球队,编号从1至N.联赛采用主客场双循环赛制,参赛球队两两之间在双方主场各赛一场. 联赛战罢,结果已经尘埃落定.此时,联赛主席 ...
- PAT A1127 ZigZagging on a Tree (30 分)——二叉树,建树,层序遍历
Suppose that all the keys in a binary tree are distinct positive integers. A unique binary tree can ...
- 04-树6 Complete Binary Search Tree(30 分)
title: 04-树6 Complete Binary Search Tree(30 分) date: 2017-11-12 14:20:46 tags: - 完全二叉树 - 二叉搜索树 categ ...
- PTA 7-2 二叉搜索树的结构(30 分)
7-2 二叉搜索树的结构(30 分) 二叉搜索树或者是一棵空树,或者是具有下列性质的二叉树: 若它的左子树不空,则左子树上所有结点的值均小于它的根结点的值:若它的右子树不空,则右子树上所有结点的值均大 ...
随机推荐
- validform.js+layer.js 表单验证样式
$("#formAdd").Validform({ tiptype: function (msg, o, cssctl) { if (o.type == 3) {//失败 laye ...
- java 加密之消息摘要算法
简介 消息摘要算法的主要特征是加密过程不需要密钥,并且经过加密的数据无法被解密,即单向加密,只有输入相同的明文数据经过相同的消息摘要算法才能得到相同的密文. 消息摘要算法不存在密钥的管理与分发问题,适 ...
- 异常来自HRESULT:0x80070422
今天同事使用一个用VB.NET2008开发的应用程序时提示“出现了下列应用程序错误:无法启动服务,原因可能是已被禁用或与其相关联的设备没有启动.(异常来自HRESULT:0x80070422)” ...
- Ubuntu下常用强化学习实验环境搭建(MuJoCo, OpenAI Gym, rllab, DeepMind Lab, TORCS, PySC2)
http://lib.csdn.net/article/aimachinelearning/68113 原文地址:http://blog.csdn.net/jinzhuojun/article/det ...
- CSS3之嵌入Web字体
之前如果想在自己的网站使用某些好看的字体,总是迫不得已得在PS里先把字体图片做好.虽然这样做也能达到我们想要的效果,但是这样就增加了HTTP请求(如果在多处使用的话),即使合并所有图片,也不好管理,灵 ...
- RabbitMQ 一个demo
Code: using System; using System.Collections.Generic; using System.Linq; using System.Text; using Sy ...
- python 返回系统位数
# For bit it will and bit it will import struct print()
- 多目标跟踪方法 NOMT 学习与总结
多目标跟踪方法 NOMT 学习与总结 ALFD NOMT MTT 读 'W. Choi, Near-Online Multi-target Tracking with Aggregated Local ...
- CentOS 6.5安装和配置ngix
一.安装配置ngix 这里用wget直接拉取并安装资源文件 首先安装必要的库(nginx 中gzip模块需要 zlib 库,rewrite模块需要 pcre 库,ssl 功能需要openssl库). ...
- Leetcode 53
//经典class Solution { public: int maxSubArray(vector<int>& nums) { ; int maxsum = -INT_MAX; ...