UVA 11280 - Flying to Fredericton SPFA变形
题目大意:
给出n(2<=n<=100)个城市之间的m(0<=m<=1000)条航线以及对应的机票价格,要求回答一些询问,每个询问是给出最大停留次数S,求从其实城市Calgary到终点城市Fredericton中途停留次数不超过s的最便宜的路程。
思路:
这题坑爹的是用城市名,不是直接编号了,嗯,map搞定之。
SPFA的变形,用二维数组dis[i][j]记录到顶点i步数为j的最短路径。
最后根据要求的s遍历一下即可~
坑爹的是s可能大于顶点数, 然后我初始化坑了一回QAQ
#include<cstdio>
#include<cstring>
#include<string>
#include<map>
#include<queue>
#include<algorithm>
#include<iostream>
using namespace std;
const int MAXN=100+10;
const int MAXM=1000+10;
const int INF=99999999;
int head[MAXN],len,n,m,dis[MAXN][MAXN],vis[MAXN][MAXN];
struct edge
{
int to,val,next;
}e[MAXM]; void add(int from,int to,int val)
{
e[len].to=to;
e[len].val=val;
e[len].next=head[from];
head[from]=len++;
}
struct node
{
int id,cnt;
node(int x,int c){cnt=c; id=x;}
}; void spfa(int s,int target,int tol)
{
memset(vis,0,sizeof(vis));
for(int i=0;i<=n+1;i++) //n+1坑啊,WA到爆,检查一个多小时才发现!!!
for(int j=0;j<=n+1;j++)
dis[i][j]=INF; queue<node> q;
q.push(node(s,0));
vis[s][0]=true;
dis[s][0]=0; while(!q.empty())
{
node cur=q.front();
q.pop();
vis[cur.id][cur.cnt]=false;
for(int i=head[cur.id];i!=-1;i=e[i].next)
{
int id=e[i].to;
if(e[i].val + dis[cur.id][cur.cnt] < dis[id][cur.cnt+1])
{
dis[id][cur.cnt+1] = e[i].val + dis[cur.id][cur.cnt] ;
if(!vis[id][cur.cnt+1])
{
vis[id][cur.cnt+1]=true;
q.push(node(id,cur.cnt+1));
}
}
} }
} int main()
{
int T;
scanf("%d",&T);
for(int ri=1;ri<=T;ri++)
{
memset(head,-1,sizeof(head));
len=0;
map<string,int> name; scanf("%d",&n);
string a,b;
for(int i=1;i<=n;i++)
{
cin>>a;
name[a]=i;
}
int cost;
scanf("%d",&m);
for(int i=0;i<m;i++)
{
cin>>a>>b>>cost;
add(name[a],name[b],cost);
} int start=name["Calgary"],fin=name["Fredericton"];
int k,tolerate;
scanf("%d",&k);
if(ri!=1)
printf("\n"); spfa(start,fin,n+1);
printf("Scenario #%d\n",ri);
for(int i=0;i<k;i++)
{
scanf("%d",&tolerate);
tolerate= min(tolerate, n); //坑啊 int ans=INF;
for(int j=0;j<=tolerate+1;j++)
ans=min(dis[fin][j],ans); if(ans!=INF)
printf("Total cost of flight(s) is $%d\n", ans);
else
printf("No satisfactory flights\n");
}
} return 0;
}
UVA 11280 - Flying to Fredericton SPFA变形的更多相关文章
- UVa 11280 Flying to Fredericton (DP + Dijkstra)
题意:给出n(2<=n<=100)个城市之间的m(0<=m<=1000)条航线以及对应的机票价格,要求回答一些询问,每个询问是给出最大停留次数S,求从其实城市Calgary到终 ...
- NOIP2009最优贸易[spfa变形|tarjan 缩点 DP]
题目描述 C 国有 n 个大城市和 m 条道路,每条道路连接这 n 个城市中的某两个城市.任意两个 城市之间最多只有一条道路直接相连.这 m 条道路中有一部分为单向通行的道路,一部分 为双向通行的道路 ...
- UVa 12661 Funny Car Racing - spfa
很简单的一道最短路问题.分情况处理赛道的打开和关闭. Code /** * UVa * Problem#12661 * Accepted * Time:50ms */ #include<iost ...
- UVA 11090 Going in Cycle!! SPFA判断负环+二分
原题链接:https://uva.onlinejudge.org/index.php?option=com_onlinejudge&Itemid=8&page=show_problem ...
- UVA 11090 - Going in Cycle!! SPFA
http://uva.onlinejudge.org/index.php?option=com_onlinejudge&Itemid=8&page=show_problem&p ...
- loj 1002(spfa变形)
题目链接:http://acm.hust.edu.cn/vjudge/problem/viewProblem.action?id=25828 题意:求所有点到给定的目标顶点的路径上的权值的最大值的最小 ...
- [HDU 1317]XYZZY[SPFA变形][最长路]
题意: 一个图, 点权代表走到该点可获得的能量值. 可正可负. 一个人从1 号出发,带有100点能量. 问是否有一种方案可使人在能量值>0的时候走到n. 思路: 这个题首先要注意点权. 其实就是 ...
- 【Uva 11280 飞到弗雷德里顿】
·你可以尽情地坐飞机,但停留次数遭到限制. ·英文题,述大意: 给出一张有向图,起点是输入的第一个城市,终点是输入的最后一个城市.给出q个询问,每个询问含一个t,表示 #include&l ...
- UVA-11280 Flying to Fredericton (dijkstra)
题目大意:一张有向图,n个节点,m条边,有边权.求从起点到终点在最多经过s个中间节点(不包括始末点)时的最小权和. 题目分析:因为起点和终点是固定的,只需一次dijkstra打出表dis[u][k], ...
随机推荐
- LaTeX Subfigure 中间加入垂直线
近期论文用到这个效果. 先实现下, 嘿嘿. \documentclass{article} \usepackage{tikz,lscape,amsmath} \usepackage[margin=1c ...
- Thinkphp5图片上传正常,音频和视频上传失败的原因及解决
Thinkphp5图片上传正常,音频和视频上传失败的原因及解决 一.总结 一句话总结:php中默认限制了上传文件的大小为2M,查找错误的时候百度,且根据错误提示来查找错误. 我的实际问题是: 我的表单 ...
- Unable to find required classes (javax.activation.DataHandler and javax.mail.internet.MimeMultipart). Attachment support is disa
转自:https://blog.csdn.net/ouyangtianhan/article/details/6797999 Unable to find required classes (java ...
- Zabbix自动发现与自动注册.
一, 自动发现与自动注册 自动发现? 当场景中出现要添加很多台主机的时候,一台台添加难免太过于繁琐,zabbix提供自动注册,自动发现,可以实现主机的批量添加, zabbix的发现包括三种类型: # ...
- centos7基础配置
记录虚拟机安装完成后的初始配置: 1.网络: 桥接方式,设置静态ip,与物理机同一网段 Ip配置 配置完成 service network restart ,重启网络后 物理机可ssh连接虚拟机系统. ...
- C# 的时间戳 在flash actionscript中使用
眼下在做一个项目,要以字节的方式传时间戳到flash中, 错误的就不写了.仅仅写一个能够使用的例如以下: C# DateTime centuryBegin = new DateTime(1970, 1 ...
- 36.intellij idea 如何一键清除所有断点
转自:https://www.cnblogs.com/austinspark-jessylu/p/7799212.html 1.在idea左下方找到"View Breakpoints&quo ...
- 关于bcg库记忆界面的问题及其解决办法
作者:朱金灿 来源:http://blog.csdn.net/clever101 今天同事向我请教一个问题,说他使用BCG创建了一个停靠栏,之后把代码注释了,但是程序启动时总出现一个Debug Ass ...
- 企业网管软件之SOLARWINDS实战-制作拓扑图
企业网管软件之SOLARWINDS实战-制作拓扑图-开始 企业网管软件之SOLARWINDS实战-制作拓扑图 本文出自 "李晨光原创技术博客" 博客,谢绝转载!
- go reflect 调用方法
package main import ( "fmt" "reflect" ) type A struct { } func (A) Test() { fmt. ...