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 分) 二叉搜索树或者是一棵空树,或者是具有下列性质的二叉树: 若它的左子树不空,则左子树上所有结点的值均小于它的根结点的值:若它的右子树不空,则右子树上所有结点的值均大 ...
随机推荐
- Check out our list of adidas NMD Singapore retailers
The adidas NMD Singapore is confirmed to produce on The month of january 14th at select adidas Origi ...
- hdu5139
这题需要我们计算 这个 因为n<10000000空间过大 那么我们可以计算出 当n可以被10整除的时候我们就将n/10记录下来当我们要查询的时候去暴力计算他们与整十之间的数去暴力去做就好了 这个 ...
- Redis 资料整理
Redis is an open source, BSD licensed, advanced key-value store. Redis is often referred to as a dat ...
- 去掉每行最后n个字符
awk '{sub(/.{n}$/,"")}1' nation.tbl > nation.tbl2 把n替换成具体长度
- Python笔记 #18# Pandas: Grouping
10 Minutes to pandas 引 By “group by” we are referring to a process involving one or more of the foll ...
- 将vi打造成IDE
一.环境 发行版:Ubuntu 18.04 LTS 代号:bionic 内核版本:4.15.0-33-generic 二.步骤 2.1 准备工作 sudo apt-get install python ...
- LightOJ 1071 Baker Vai(拆点+最大费用流)题解
题意:给一个n*m的方格,每个格子上都有一个数字表示价值,小A在左上角,他从左上角走到右下角只能向右或向下走,然后再从右下角走上左上角,这次只能向上或向左走,这两条路绝对没有重复,问你怎样走有最大价值 ...
- [bug report] 当springboot报错 找不到类 javax.xml.bind.JAXBException
<!--以下四个依赖均是javax.xml.bind.JAXBException的依赖 在java6/7/8默认支持,java9不再支持--> <dependency> < ...
- Gym - 101334C 3514 无向仙人掌
http://codeforces.com/gym/101334/attachments 题意: 判断是否是仙人掌图并且连通,如果是的话则计算出它有多少个连通子图也是仙人掌. 思路:连通子图也就是我们 ...
- redis优缺点
redis主要是一个内存数据库.很多时候是被作为缓存来使用.redis的优势主要体现在和其他缓存方案进行比较,redis的不足主要是和其他数据库进行比较时体现的. 优点: 读写性能优异 支持数据持久化 ...