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;
}

最新文章

  1. 哪种缓存效果高?开源一个简单的缓存组件j2cache
  2. C语言基础(8)-const,volatile,register关键字
  3. 关于OpenVPN的入门使用
  4. ServiceStack.Redis之IRedisClient&lt;第三篇&gt;
  5. Bootstrap系列 -- 21. 表单提示信息
  6. pomelo架构概览
  7. Sql查询除ID以外相同的数据
  8. Centos6.4_X64飞信安装
  9. 正式学习 React(三)番外篇 reactjs性能优化之shouldComponentUpdate
  10. 二.创建maven工程及下载需要的jar包
  11. 产品经理学Python:for循环、while循环
  12. Chrome DevTools 调研笔记
  13. Android破解学习之路(六)——Android游戏 方块冒险 破解
  14. 解决Warning: mysql_connect(): Headers and client library minor version mismatch. 警告
  15. 如何Python下载大文件?
  16. codeforces 980A Links and Pearls
  17. IIS W3C日志记录字段和HTTP状态代码的说明
  18. Djangon 基础总结 汇总 从请求到返回页面的过程,
  19. python 阿狸的进阶之路(7)
  20. eclipse/intellij idea 查看java源码和注释

热门文章

  1. modSecurity规则学习(二)——配置文件
  2. C#导出EXCEL(DataTable导出EXCEL)
  3. host---域名查询
  4. 今日SGU 5.9
  5. springboot整合Beetl、BeetlSql实现ajax分页
  6. samba-设定文件共享
  7. actionmode-ActionMode以及它的menu使用
  8. 为RecyclerView添加item的点击事件
  9. POJ 1874 畅通工程续(最短路模板题)
  10. POJ——T 1006 Biorhythms