POJ 1273 网络流(最大流)模板
http://poj.org/problem?id=1273
这道题很值得反思,弄了一下午,交上去先是一直编译错误,而在本地运行没有问题,
原因可能是oj的编译器版本老旧不支持这样的写法
G[from].push_back((edge){to,cap,G[to].size()});
G[to].push_back((edge){from,0,G[from].size() - 1});
这两句交上去是不能通过的,不知道网上很多人这样子贴出代码是怎样通过的(‘白书’的模板有问题的)
如果是照着‘白书’直接敲上去没有提交试试的话就太不应该了
正确的写法:
struct edge edge1={to,cap,G[to].size()} ;
G[from].push_back(edge1);
struct edge edge2={from,0,G[from].size()-1};
G[to].push_back(edge2);
解决了这个问题以后就开始一直WA
原因:虽然记得给数组memset了,但是vector忘记初始化,使得后面的结果出错
这些教训要接受
#include <iostream>
#include <queue>
#include <vector>
#include <string.h>
#define MAXN 205
#define oo 0x3f3f3f3f
using namespace std;
struct edge
{
int to;//终点
int cap;//容量
int rev;//反向边
};
vector <edge> G[MAXN];
int level[MAXN];//顶点到源点的距离编号
int iter[MAXN];//当前弧,在其之前的边不用再考虑
void add_edge(int from,int to,int cap)//增加s->t容量cap的边
{
struct edge edge1={to,cap,G[to].size()} ;
G[from].push_back(edge1);
struct edge edge2={from,,G[from].size()-};
G[to].push_back(edge2);
}
//bfs用来计算从源点出发所有点的距离编号
void bfs(int s)
{
memset(level, -, sizeof(level));
queue<int> que;
level[s] = ;
que.push(s);
while (!que.empty()) {
int v = que.front(); que.pop();
for (int i = ; i < G[v].size(); i++) {
edge &e = G[v][i];
if (e.cap > && level[e.to] < ) {
level[e.to] = level[v] + ;
que.push(e.to);
}
}
}
}
//通过DFS寻找当前的最短的增广路
int dfs(int v, int t, int f)
{
if (v == t) return f;
for (int &i = iter[v]; i < G[v].size(); i++) {//这里用引用,巧妙地修改了iter数组
edge &e = G[v][i];
if (e.cap > && level[v] < level[e.to]) {//level[v] < level[e.to]这个条件保证了当前的增广路是最短的
int d = dfs(e.to, t, min(f, e.cap));
if (d > ) {
e.cap -= d;
G[e.to][e.rev].cap += d;
return d;
}
}
}
return ;
}
int max_flow(int s, int t)
{
int flow = ;
for(;;)
{
bfs(s);
if (level[t] < ) return flow;
memset(iter, , sizeof(iter));
int f;
while ((f = dfs(s, t, oo)) > ) {
flow += f;
}
}
} void init()
{
for(int i = ; i < MAXN; i++)
{
G[i].clear();
}
} int main()
{
int n,m,s,e,c,i; while(scanf("%d%d",&n,&m)!=EOF)
{
init();
for(i=;i<=n;i++)
{
scanf("%d%d%d",&s,&e,&c);
add_edge(s,e,c);
}
cout<<max_flow(,m)<<endl;
}
return ;
}
POJ 1273 网络流(最大流)模板的更多相关文章
- 网络流-最大流 模板(poj 1273)
#include<cstdio> #include<iostream> #include<cstring> #include<queue> #defin ...
- POJ 1149PIGS 网络流 最大流
PIGS Time Limit: 1000MS Memory Limit: 10000K Total Submissions: 20421 Accepted: 9320 Description ...
- POJ1273 网络流-->最大流-->模板级别-->最大流常用算法总结
一般预流推进算法: 算法思想: 对容量网络G 的一个预流f,如果存在活跃顶点,则说明该预流不是可行流. 预流推进算法就是要选择活跃顶点,并通过它把一定的流量推进到它的邻接顶点,尽可能将正的赢余减少为0 ...
- Poj(1273),最大流,EK
Drainage Ditches Time Limit: 1000MS Memory Limit: 10000K Total Submissions: 69355 Accepted: 2687 ...
- POJ 1273 (基础最大流) Drainage Ditches
虽然算法还没有理解透,但以及迫不及待地想要A道题了. 非常裸的最大流,试试lrj的模板练练手. #include <cstdio> #include <cstring> #in ...
- POJ 3281 [网络流dinic算法模板]
题意: 农场主有f种食物,d种饮料,n头牛. 接下来的n行每行第一个数代表第i头牛喜欢吃的食物数量,和第i头牛喜欢喝的饮料数目. 接下来分别是喜欢的食物和饮料的编号. 求解:农场主最多能保证几头牛同时 ...
- P3376 网络流-最大流模板题(Dinic+当前弧优化)
(点击此处查看原题) Dinic算法 Dinic算法相对于EK算法,主要区别在于Dinic算法对图实现了分层,使得我们可以用一次bfs,一次dfs使得多条增广路得到增广 普通的Dinic算法已经可以处 ...
- 【模板】网络流-最大流模板(Dinic)
#include <cstdio> #include <cstring> #include <algorithm> #include <queue> u ...
- [POJ1273][USACO4.2]Drainage Ditches (网络流最大流)
题意 网络流最大流模板 思路 EK也不会超时 所以说是一个数据比较水的模板题 但是POJ有点坑,多组数据,而且题目没给 哭得我AC率直掉 代码 用的朴素Dinic #include<cstdio ...
随机推荐
- String类中的一些函数使用方法
最常用的就是Length()函数了,求字符串的长度 String s="";int i=s.length();i结果为0. 如果是String s=null;int i=s.len ...
- javac 及 java命令的使用问题(错误或无法加载主类)
一.问题 使用 javac 命令编译完.java源文件后,用 java 命令运行.class文件时,通常会遇到如下或类似的问题: 错误: 找不到或无法加载主类 HelloWorld.class 二.解 ...
- Outlook2003收到的邮件不能显示图片,但转发或回复可以 故障排错
转自:http://wenku.baidu.com/link?url=4O0Wpsnk_OasA7B-M4KMJ4H-WnLicT4vfVOT7AvXhTjpn-p2gBTNsXR4W230r0gAE ...
- Make命令
Make命令 一.Make的概念 Make这个词,英语的意思是"制作".Make命令直接用了这个意思,就是要做出某个文件.比如,要做出文件a.txt,就可以执行下面的命令. $ m ...
- HttpHandler过滤请求..
记得以前写过一篇..后来找不到了..我自己也忘记怎么弄了.. 在网上找了很多的教程..写的总有瑕疵..感觉不顺畅.. 自己来一篇.. 其实很简单.. 先建立一个类 继承并实现接口 IHttpHand ...
- Web框架们
Python之路[第十八篇]:Web框架们 Python的WEB框架 Bottle Bottle是一个快速.简洁.轻量级的基于WSIG的微型Web框架,此框架只由一个 .py 文件,除了Pytho ...
- Jedis 例子(demo)大全
第一步:到git下载jedis源码,如果你用maven或者gradle,那么直接下官方的即可,地址:https://github.com/xetorthio/jedis:如果你用ant,下载这个:ht ...
- oracle 的wm_concat函数使用
转载自:http://blog.itpub.net/post/42245/522757 首先让我们来看看这个神奇的函数wm_concat(列名),该函数可以把列值以","号分隔起来 ...
- java.lang.reflect.Constructor
java.lang.reflect.Constructor 一.Constructor类是什么 Constructor是一个类,位于java.lang.reflect包下. 在Java反射中 Cons ...
- [设计模式] javascript 之 责任链模式
责任链模式:定义 责任链接模式又称职责链模式,是一种对象的行为模式:它是一种链式结构,每个节点都有可能两种操作,要么处理该请求停止该请求操作,要么把请求转发到下一个节点,让下一个节点来处理请求:该模式 ...