http://uva.onlinejudge.org/index.php?option=com_onlinejudge&Itemid=8&page=show_problem&category=&problem=2255&mosmsg=Submission+received+with+ID+13067799

题目大意:

给出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变形的更多相关文章

  1. UVa 11280 Flying to Fredericton (DP + Dijkstra)

    题意:给出n(2<=n<=100)个城市之间的m(0<=m<=1000)条航线以及对应的机票价格,要求回答一些询问,每个询问是给出最大停留次数S,求从其实城市Calgary到终 ...

  2. NOIP2009最优贸易[spfa变形|tarjan 缩点 DP]

    题目描述 C 国有 n 个大城市和 m 条道路,每条道路连接这 n 个城市中的某两个城市.任意两个 城市之间最多只有一条道路直接相连.这 m 条道路中有一部分为单向通行的道路,一部分 为双向通行的道路 ...

  3. UVa 12661 Funny Car Racing - spfa

    很简单的一道最短路问题.分情况处理赛道的打开和关闭. Code /** * UVa * Problem#12661 * Accepted * Time:50ms */ #include<iost ...

  4. UVA 11090 Going in Cycle!! SPFA判断负环+二分

    原题链接:https://uva.onlinejudge.org/index.php?option=com_onlinejudge&Itemid=8&page=show_problem ...

  5. UVA 11090 - Going in Cycle!! SPFA

    http://uva.onlinejudge.org/index.php?option=com_onlinejudge&Itemid=8&page=show_problem&p ...

  6. loj 1002(spfa变形)

    题目链接:http://acm.hust.edu.cn/vjudge/problem/viewProblem.action?id=25828 题意:求所有点到给定的目标顶点的路径上的权值的最大值的最小 ...

  7. [HDU 1317]XYZZY[SPFA变形][最长路]

    题意: 一个图, 点权代表走到该点可获得的能量值. 可正可负. 一个人从1 号出发,带有100点能量. 问是否有一种方案可使人在能量值>0的时候走到n. 思路: 这个题首先要注意点权. 其实就是 ...

  8. 【Uva 11280 飞到弗雷德里顿】

    ·你可以尽情地坐飞机,但停留次数遭到限制. ·英文题,述大意:       给出一张有向图,起点是输入的第一个城市,终点是输入的最后一个城市.给出q个询问,每个询问含一个t,表示 #include&l ...

  9. UVA-11280 Flying to Fredericton (dijkstra)

    题目大意:一张有向图,n个节点,m条边,有边权.求从起点到终点在最多经过s个中间节点(不包括始末点)时的最小权和. 题目分析:因为起点和终点是固定的,只需一次dijkstra打出表dis[u][k], ...

随机推荐

  1. 5.cocos2d锚点

    创建一个层T1LayerAnchorPoint AppDelegate.cpp bool AppDelegate::applicationDidFinishLaunching() { // initi ...

  2. BZOJ 1231 状压DP

    思路: f[i][j] i表示集合的组成 j表示选最后一个数 f[i][j]表示能选的方案数 f[i|(1<< k)][k]+=f[i][j]; k不属于i j属于i且符合题意 最后Σf[ ...

  3. #学习记录#——CSS content 属性

    CSS content 属性常结合:before 和:after 这两个伪类一起使用,给指定的元素添加内容来丰富页面. 1. 添加文本内容 html: <h1>给末尾添加内容. </ ...

  4. 【Python学习】爬虫报错处理bs4.FeatureNotFound

    [BUG回顾] 在学习Python爬虫时,运Pycharm中的文件出现了这样的报错: bs4.FeatureNotFound: Couldn’t find a tree builder with th ...

  5. Python Web框架要点

    1. Web应用程序处理流程 前端客户端(浏览器.APP.ajax.爬虫程序)>>>--http的请求与响应--<<<服务器程序(Gunicorn.uwsig)&l ...

  6. 漫话C++之string字符串类的使用(有汇编分析)

    C++中并不提倡继续使用C风格的字符串,而是为字符串定义了专门的类,名为string. 使用前的准备工作 在使用string类型时,需要包含string头文件,且string位于std命名空间内: # ...

  7. 单位阶跃函数(Heaviside/unit step function)—— 化简分段函数

    注意,单位阶跃函数一种不连续函数. 1. 常见定义 最经典的定义来自于 Ramp function(斜坡函数,max{x,0})的微分形式: H(x)=ddxmax{x,0} 2. 化简分段函数 如对 ...

  8. jQuery post 传递 iframe

    //使用POST链接iframe function doOpenPostIfrm(url, args, iframe) { //创建一个隐藏表单 var _form = $("<for ...

  9. Java学习笔记八

    IO流:就是input/output输入/输出流. 一.字节流操作文件的便捷类:FileWriter和FileReader import java.io.FileWriter; import java ...

  10. React项目编译node内存溢出

    坑爹的node 内存溢出 react开发项目  安装一个插件依赖 ,然后就报错了 报错如下(自己的没有截图出来 这是从别人的截图---报错基本差不多) 之前因为项目大而且旧的原因  使用 过      ...