poj2263 zoj1952 Heavy Cargo(floyd||spfa)
这道题数据范围小,方法比较多。我用floyd和spfa分别写了一下,spfa明显有时间优势。
一个小技巧在于:把城市名称对应到数字序号,处理是用数字。
方法一:spfa
#include<iostream>
#include<cstdio>
#include<cstdlib>
#include<cstring>
#include<string>
#include<cmath>
#include<map>
#include<set>
#include<vector>
#include<algorithm>
#include<stack>
#include<queue>
#include<cctype>
#include<sstream>
using namespace std;
#define pii pair<int,int>
#define LL long long int
const int eps=1e-;
const int INF=;
const int maxn=+;
int n,r,cas=,ton,num,used[maxn],d[maxn],m[maxn][maxn];
char city[maxn][];
char s[],e[];
vector<int>v[maxn];
int index(char *ss)
{
int i;
for(i=;i<num;i++)
{
if(strcmp(ss,city[i])==)
{
return i;
}
}
strcpy(city[num++],ss);
return i;
}
void ini()
{
num=;
for(int i=;i<n;i++)
{
strcpy(city[i],"\0");
v[i].clear();
used[i]=;
d[i]=INF;
}
}
int spfa(int s,int e)
{
queue<int>q;
q.push(s);
used[s]=;
while(!q.empty())
{
int t=q.front();
used[t]=;
q.pop();
int siz=v[t].size();
for(int i=;i<siz;i++)
{
int k=v[t][i];
/*if(used[k]==0) {q.push(k);used[k]=1;}
if(d[k]<INF) d[k]=max(d[k],min(d[t],m[t][k]));
else d[k]=min(d[t],m[t][k]);*/
/*上面注释掉的这种写法不对,一旦有环就会陷入死循环(即使这题不会有
负边)。还是对spfa理解的不够。需要更新的点才要考虑入队的问题,不需要
更新的点肯定不入队,最后所有点都不用再更新了队列为空退出循环。而不是
遇到一个点就入队。*/
if(d[k]==INF)
{
d[k]=min(d[t],m[t][k]);
q.push(k);used[k]=;
}
else if(min(d[t],m[t][k])>d[k])
{
d[k]=min(d[t],m[t][k]);
if(used[k]==) {q.push(k);used[k]=;}
}
}
}
return d[e];
}
int main()
{
//freopen("in8.txt","r",stdin);
//freopen("out.txt","w",stdout);
while(scanf("%d%d",&n,&r)==)
{
if(n==&&r==) break;
printf("Scenario #%d\n",++cas);
ini();
for(int i=;i<r;i++)
{
scanf("%s%s%d",s,e,&ton);
int t1=index(s);
int t2=index(e);
v[t1].push_back(t2);
v[t2].push_back(t1);
m[t1][t2]=m[t2][t1]=ton;
}
scanf("%s%s",s,e);
int t1=index(s);
int t2=index(e);
printf("%d tons\n",spfa(t1,t2));
printf("\n");
}
//fclose(stdin);
//fclose(stdout);
return ;
}
spfa
方法二:floyd
#include<iostream>
#include<cstdio>
#include<cstdlib>
#include<cstring>
#include<string>
#include<cmath>
#include<map>
#include<set>
#include<vector>
#include<algorithm>
#include<stack>
#include<queue>
#include<cctype>
#include<sstream>
using namespace std;
#define pii pair<int,int>
#define LL long long int
const int eps=1e-;
const int INF=;
const int maxn=+;
int n,r,m[maxn][maxn],cas=,ton,num;
char city[maxn][];
char s[],e[];
int index(char *ss)
{
int i;
for(i=;i<num;i++)
{
if(strcmp(ss,city[i])==)
{
return i;
}
}
strcpy(city[num++],ss);
return i;
}
void floyd()
{
for(int k=;k<n;k++)
{
for(int i=;i<n;i++)
{
for(int j=;j<n;j++)
{
m[i][j]=max(m[i][j],min(m[i][k],m[k][j]));
}
}
}
}
void ini()
{
num=;
for(int i=;i<n;i++)
{
strcpy(city[i],"\0");
for(int j=;j<n;j++)
{
if(i==j) m[i][j]=INF;
else m[i][j]=;
}
}
}
int main()
{
//freopen("in8.txt","r",stdin);
//freopen("out.txt","w",stdout);
while(scanf("%d%d",&n,&r)==)
{
if(n==&&r==) break;
printf("Scenario #%d\n",++cas);
ini();
for(int i=;i<r;i++)
{
scanf("%s%s%d",s,e,&ton);
int t1=index(s);
int t2=index(e);
m[t1][t2]=m[t2][t1]=ton;
}
floyd();
scanf("%s%s",s,e);
int t1=index(s);
int t2=index(e);
printf("%d tons\n",m[t1][t2]);
printf("\n");
}
//fclose(stdin);
//fclose(stdout);
return ;
}
floyd
poj2263 zoj1952 Heavy Cargo(floyd||spfa)的更多相关文章
- POJ2263 Heavy Cargo
Heavy Cargo Time Limit: 1000MS Memory Limit: 65536K Total Submissions: 4004 Accepted: 2124 Descr ...
- POJ 2263 Heavy Cargo(Floyd + map)
Heavy Cargo Time Limit: 1000MS Memory Limit: 65536K Total Submissions: 3768 Accepted: 2013 Descr ...
- ACM/ICPC 之 最短路-Floyd+SPFA(BFS)+DP(ZOJ1232)
这是一道非常好的题目,融合了很多知识点. ZOJ1232-Adventrue of Super Mario 这一题折磨我挺长时间的,不过最后做出来非常开心啊,哇咔咔咔 题意就不累述了,注释有写,难点在 ...
- Heavy Cargo POJ 2263 (Floyd传递闭包)
Description Big Johnsson Trucks Inc. is a company specialized in manufacturing big trucks. Their lat ...
- poj 1847( floyd && spfa )
http://poj.org/problem?id=1847 一个水题,用来熟悉熟悉spfa和floyd的. 题意:有m条的铁路,要从x,到y, 之后分别就是条铁路与其他铁路的交点.第一个输入的为有n ...
- K - Heavy Cargo dijkstar
来源poj2263 Big Johnsson Trucks Inc. is a company specialized in manufacturing big trucks. Their lates ...
- poj1847 Tram(Dijkstra || Floyd || SPFA)
题目链接 http://poj.org/problem?id=1847 题意 有n个车站,编号1~n,每个车站有k个出口,车站的出口默认是k个出口中的第一个,如果不想从默认出口出站,则需要手动选择出站 ...
- hdoj2544 最短路(Dijkstra || Floyd || SPFA)
题目链接 http://acm.hdu.edu.cn/showproblem.php?pid=2544 思路 最短路算法模板题,求解使用的Dijkstra算法.Floyd算法.SPFA算法可以当做求解 ...
- [APIO2017]商旅——分数优化+floyd+SPFA判负环+二分答案
题目链接: [APIO2017]商旅 枚举任意两个点$(s,t)$,求出在$s$买入一个物品并在$t$卖出的最大收益. 新建一条从$s$到$t$的边,边权为最大收益,长度为原图从$s$到$t$的最短路 ...
随机推荐
- 进程理论基础(Day32)
背景知识 顾名思义,进程即一个软件正在进行的过程.进程是对正在运行程序的一个抽象. 进程的概念起源于操作系统,是操作系统最核心的概念,也是操作系统提供的最古老的也是最重要的抽象概念之一.操作系统的其他 ...
- python数据之间的转换和关系
首先数据类型在我看来分为两类: 容器类:能存储数据,例如:元祖.列表.集合.字符串. 原子类:单纯保存数值,例如:整数.浮点数.复数. 容器类与容器类之间,一般都可以进行两两之间的转化. 原子类与原子 ...
- Linux:文件
Linux:文件 文件属性 用户分为三种:文件拥有者.群组以及其它人,对不同的用户有不同的文件权限. 使用 ls 查看一个文件时,会显示一个文件的信息,例如 drwxr-xr-x. 3 root ro ...
- 17 南宁区域赛 F - The Chosen One 【规律】
题目链接 https://nanti.jisuanke.com/t/19972 题意 给出一个n 然后将 n 个数 标号为 1 -> n 按顺序排列 每次抽掉 奇数位的数 然后求最后剩下那个数字 ...
- ZOJ 3959 Problem Preparation 【水】
题目链接 http://acm.zju.edu.cn/onlinejudge/showProblem.do?problemCode=3959 AC代码 #include <cstdio> ...
- [转] 我所经历的IBM SOA与系统整合
2006年,一汽大众新上来一位总经理,新加坡人,整个一国际背景高端管理人才,是德国人和中国人博弈后取得的胜利. 一汽大众过去是从总部到区域到终端一体化的大盘管理模式,很僵化很粘稠,不利用快速反应.于是 ...
- HashTable的使用,扑克牌发牌游戏
l 场景 主要实现以下功能: 1. 首先给扑克牌中每张牌设定一个编号,下面算法实现的编号规则如下: 红桃按照从小到大依次为:1-13 方块按照从小到大依次为:14-26 黑桃按 ...
- Shell编程之Linux信号及信号跟踪
一.Linux信号 1.什么是信号? Linux信号是由一个整数构成的异步消息,它可以由某个进程发给其他进程,也可以在用户按下特定键发生某种异常事件时,由系统发给某个进程. 2.信号列表 [root@ ...
- ubuntu ssh免密码登录
目前很多服务(ceph,openstack等)都需要用到SSH使用ssh-key进行登录,而不能使用密码进行登录. 下面是配置步骤: 一.在SSH Client生成ssh key pair root@ ...
- 图片的另一种展现—将后台图片编码直接展现为图片
1.应用场景 开发过程中,遇到这样的需求:需要将服务器上的图片展现在页面上,但是图片所在服务器不是对外的,图片所在服务器与应用服务器也不在同一台机器上,这时候就需要在开发中先将图 ...