ACM/ICPC 之 Floyd范例两道(POJ2570-POJ2263)
两道以Floyd算法为解法的范例,第二题如果数据量较大,须采用其他解法
POJ2570-Fiber Network
//经典的传递闭包问题,由于只有26个公司可以采用二进制存储
//Time:141Ms Memory:328K
#include<iostream>
#include<cstring>
#include<cstdio>
using namespace std; #define MAX 205
#define MAXS 28 int n;
int d[MAX][MAX]; void floyd()
{
for (int k = 1; k <= n; k++)
for (int i = 1; i <= n; i++)
for (int j = 1; j <= n; j++)
d[i][j] |= d[i][k] & d[k][j]; //找出两条线路的相同公司
} int main()
{
while (scanf("%d", &n), n)
{
memset(d, 0, sizeof(d));
int a, b;
char s[MAXS];
while (scanf("%d%d", &a, &b), a && b)
{
scanf("%s", s);
int len = strlen(s);
for (int i = 0; i < len; i++)
d[a][b] |= 1 << (s[i] - 'a');
} floyd();
while (scanf("%d%d", &a, &b), a && b)
{
if (d[a][b] == 0) printf("-\n");
else {
int tmp = d[a][b];
for (int i = 0; i < 26; i++, tmp >>= 1)
if (tmp & 1) putchar('a' + i); //单个字符输出putchar较快
printf("\n");
}
}
printf("\n");
}
return 0;
}
POJ2263-Heavy Cargo
//求图中起点到终点的公路最大承载量
//Time:32Ms Memory:500K
#include<iostream>
#include<cstring>
#include<cstdio>
#include<algorithm>
using namespace std; #define MAX 205
#define MAXS 32 struct City {
char s[MAXS];
}c[MAX]; int n, m;
int lc;
int board[MAX][MAX];
int d[MAX][MAX]; int find(char s[MAXS])
{
for (int i = 0; i < lc; i++)
if (!strcmp(s, c[i].s)) return i;
return -1;
} void floyd()
{
memcpy(d, board, sizeof(board)); for (int k = 0; k < lc; k++)
for (int i = 0; i < lc; i++)
for (int j = 0; j < lc; j++)
d[i][j] = max(d[i][j], min(d[i][k], d[k][j]));
} int main()
{
int cas = 0;
while (scanf("%d%d", &n, &m), n && m)
{
int dis; lc = 0;
memset(board, -1, sizeof(board));
for (int i = 0; i < m; i++)
{
scanf("%s%s%d", c[lc].s, c[lc+1].s, &dis);
int n1 = find(c[lc].s);
int n2 = find(c[lc + 1].s);
if (n1 == -1) {
n1 = lc++;
if (n2 == -1) n2 = lc++;
}
else if (n2 == -1)
c[n2 = lc++] = c[lc + 1];
board[n1][n2] = board[n2][n1] = dis;
} char s1[MAXS], s2[MAXS];
scanf("%s%s", s1, s2);
int n1 = find(s1);
int n2 = find(s2); floyd(); printf("Scenario #%d\n", ++cas);
printf("%d tons\n\n", d[n1][n2]); } return 0;
}
ACM/ICPC 之 Floyd范例两道(POJ2570-POJ2263)的更多相关文章
- ACM/ICPC 之 SPFA范例两道(POJ3268-POJ3259)
两道以SPFA算法求解的最短路问题,比较水,第二题需要掌握如何判断负权值回路. POJ3268-Silver Cow Party //计算正逆最短路径之和的最大值 //Time:32Ms Memory ...
- ACM/ICPC 之 SPFA练习两道(ZOJ3088-ZOJ3103)
两道题都需要进行双向SPFA,比范例复杂,代码也较长,其中第二题应该可以用DFS或者BFS做,如果用DFS可能需要的剪枝较多. ZOJ3088-Easter Holydays //利用SPFA找出下降 ...
- ACM/ICPC 之 差分约束系统两道(ZOJ2770-POJ1201)
当对问题建立数学模型后,发现其是一个差分方程组,那么问题可以转换为最短路问题,一下分别选用Bellmanford-SPFA解题 ZOJ2770-Burn the Linked Camp //差分约束方 ...
- ACM/ICPC 之 Prim范例(ZOJ1586-POJ1789(ZOJ2158))
两道Prim解法范例题型,简单的裸Prim,且两题相较以边为重心的Kruskal解法而言更适合以点为重心扩展的Prim解法. ZOJ1586-QS Network 题意:见Code 题解:直接的MST ...
- ACM/ICPC 之 Kruskal范例(ZOJ1203-POJ1861(ZOJ1542))
两道最小生成树范例,Kruskal解法-以边为主体扩展最小生成树,需要利用并查集. ZOJ1203-Swordfish 题意:求n个给定平面坐标的城市中的一条平面距离上的最短路长(保留两位小数) 题解 ...
- 『ACM C++』Virtual Judge | 两道基础题 - The Architect Omar && Malek and Summer Semester
这几天一直在宿舍跑PY模型,学校的ACM寒假集训我也没去成,来学校的时候已经18号了,突然加进去也就上一天然后排位赛了,没学什么就去打怕是要被虐成渣,今天开学前一天,看到最后有一场大的排位赛,就上去试 ...
- ACM/ICPC 之 Floyd练习六道(ZOJ2027-POJ2253-POJ2472-POJ1125-POJ1603-POJ2607)
以Floyd解法为主的练习题六道 ZOJ2027-Travelling Fee //可免去一条线路中直接连接两城市的最大旅行费用,求最小总旅行费用 //Time:0Ms Memory:604K #in ...
- ACM/ICPC 之 Floyd+记录路径后继(Hdu1385(ZOJ1456))
需要处理好字典序最小的路径 HDU1385(ZOJ1456)-Minimum Transport //Hdu1385-ZOJ1456 //给定邻接矩阵,求给定起点到终点的最短路径,若有相同路长的路径按 ...
- ACM/ICPC 之 BFS范例(ZOJ2913-ZOJ1136(POJ1465))
通过几道经典BFS例题阐述BFS思路 ZOJ2913-Bus Pass 题意:找一个center区域,使得center到所有公交线路最短,有等距的center则输出id最小的. 题解:经典的BFS,由 ...
随机推荐
- Java继承和多态实例
我们知道面向对象的三大特性是封装.继承和多态.然而我们有时候总是搞不清楚这些概念.下面对这些概念进行整理, 为以后面向抽象的编程打下坚实的基础. 封装的概念还是很容易理解的.如果你会定义类,那么相信你 ...
- solr6.1-----solrJ 程序管理索引库
solrJ 是solr 提供的一个客户端,就是一个jar 包,把jar 添加到工程中整合solr 服务. 所需jar 包 D:\solr-6.1.0\dist 下面的 solr-solrj-6.1.0 ...
- CSS文档流
文档流 将窗体自上而下分成一行行, 并在每行中按从左至右的顺序排放元素,即为文档流. 每个非浮动块级元素都独占一行, 浮动元素则按规定浮在行的一端. 若当前行容不下, 则另起新行再浮动. 内联元素也不 ...
- Unix时间戳转换怎样在Excel批量修改?
最近在操作项目的时候碰到一个Unix时间戳转换的问题."date_time":1393031347这个是什么,你知道吗?如果你对Unix时间戳了解的话一眼就看出来.但我们本着科普的 ...
- CentOS启用sudo,禁用root远程登录
CentOS默认不启用sudo,且可以直接用超级管理员身份登录服务器.ubuntu这方面做得比较好,为了安全,减小误操作带来的损失,还是推荐启用sudo. 1.添加sudo用户 执行 visudo 命 ...
- ajax访问 aspx.cs后台
--前台$.ajax({ type: "POST", contentType: "application/json", url: "WebForm2. ...
- Android内存性能优化(内部资料总结)
eoe上看到的一个很好的文章 摘抄了下来留着自己看看 刚入门的童鞋肯能都会有一个疑问,Java不是有虚拟机了么,内存会自动化管理,我们就不必要手动的释放资源了,反正系统会给我们完成.其实Java中没有 ...
- BZOJ1503——郁闷的出纳员
1.题目大意:一道treap题,支持插入,询问第K大,还有全体修改+上一个值,如果某个点值小于x,那么就删除这个点 插入100000次,询问100000次,修改100次..最后输出删了多少个点 2.分 ...
- iOS中多线程原理与runloop介绍
一.线程概述 有些程序是一条直线,起点到终点:有些程序是一个圆,不断循环,直到将它切断.直线的如简单的Hello World,运行打印完,它的生命周期便结束了,像昙花一现那样:圆如操作系统,一直运行直 ...
- Apache 无法启动
本人是做前端开发的,对后台程序不太熟悉,也就以前学过一点.net.但现在都忘记的差不多了.最近在公司,经理给了我一个管理工具dedecms,我刚开始看的时候完全不懂这是什么东西,之前都没听说过(本人见 ...