#include<bits/stdc++.h>
using namespace std;
using namespace std;
typedef long long ll;
const int MAXN = 10005;
#define inf 0x3f3f3f3f3f3f3f3f struct ISAP{
int n;//实际建图总点数(最好比图中总点数大一点)
struct Edge{
int v,next;
ll cap,flow;
}edge[MAXN*100];
int cur[MAXN],pre[MAXN],gap[MAXN],path[MAXN],dep[MAXN];
int cnt=0;//实际存储总边数
void init(int n){
this -> n =n;
cnt=0;
memset(pre,-1,sizeof(pre));
}
void AddEdge(int u,int v,ll w,ll rw=0)//加边 单向图三个参数 双向图四个
{
edge[cnt] = (Edge){v,pre[u],w,0};
pre[u]=cnt++;
edge[cnt] = (Edge){u,pre[v],rw,0};
pre[v]=cnt++;
}
bool bfs(int s,int t){//其实这个bfs可以融合到下面的迭代里,但是好像是时间要长
memset(dep,-1,sizeof(dep));
memset(gap,0,sizeof(gap));
gap[0]=1;
dep[t]=0;
queue<int>q;
while(!q.empty())
q.pop();
q.push(t);//从汇点开始反向建层次图
while(!q.empty()){
int u=q.front();
q.pop();
for(int i=pre[u];i!=-1;i=edge[i].next){
int v=edge[i].v;
if(dep[v]==-1&&edge[i^1].cap>edge[i^1].flow)//注意是从汇点反向bfs,但应该判断正向弧的余量
{
dep[v]=dep[u]+1;
gap[dep[v]]++;
q.push(v);
//if(v==s)//感觉这两句优化加了一般没错,但是有的题可能会错,所以还是注释出来,到时候视情况而定
//break;
}
}
}
return dep[s]!=-1;
}
ll isap(int s,int t){
bfs(s,t);
memcpy(cur,pre,sizeof(pre));
int u=s;
path[u]=-1;
ll ans=0;
while(dep[s]<n){//迭代寻找增广路
if(u==t){
ll f=inf;
for(int i=path[u];i!=-1;i=path[edge[i^1].v])//修改找到的增广路
f=min(f,edge[i].cap-edge[i].flow);
for(int i=path[u];i!=-1;i=path[edge[i^1].v]){
edge[i].flow+=f;
edge[i^1].flow-=f;
}
ans+=f;
u=s;
continue;
}
bool flag=false;
int v;
for(int i=cur[u];i!=-1;i=edge[i].next){
v=edge[i].v;
if(dep[v]+1==dep[u]&&edge[i].cap-edge[i].flow){
cur[u]=path[v]=i;//当前弧优化
flag=true;
break;
}
}
if(flag){
u=v;
continue;
}
int x=n;
if(!(--gap[dep[u]]))return ans;//gap优化
for(int i=pre[u];i!=-1;i=edge[i].next){
if(edge[i].cap-edge[i].flow&&dep[edge[i].v]<x){
x=dep[edge[i].v];
cur[u]=i;//常数优化
}
}
dep[u]=x+1;
gap[dep[u]]++;
if(u!=s)//当前点没有增广路则后退一个点
u=edge[path[u]^1].v;
}
return ans;
}
}F;

最新文章

  1. [Asp.net]常见word,excel,ppt,pdf在线预览方案,有图有真相,总有一款适合你!
  2. 如何写出优雅的Python
  3. asp.Net获取脚本传过来的参数的方法汇总
  4. Mac 在命令行中获得Root权限
  5. C语言可变参数函数实现原理
  6. [转载] 数据测试常用的Data Profiling方法
  7. 简论:int i = 0
  8. CSS本页写样式
  9. [SAP ABAP开发技术总结]几个小问题
  10. 去除html标签 正则 &lt;.+?&gt; 解释
  11. 一些web编程能用到的小知识
  12. [置顶] 请听一个故事------&gt;你真的认为iPhone只是一部手机?苹果惊天秘密!!
  13. 使用JS通过正则限制input的输入
  14. 卸载oracle 11g数据库
  15. NET .NET深入体验和实战精要
  16. python笔记十四(高阶函数——map/reduce、filter、sorted)
  17. alertjs Documentation
  18. 平时在PHP编码时有没有注意到这些问题
  19. java 大文件上传 断点续传 完整版实例 (Socket、IO流)
  20. fl包下的TransitionManager的使用

热门文章

  1. iOS开发之--最简单的导航按钮更换方法/导航颜色的改变
  2. U盘重装Windows系统
  3. 第五篇:CUDA 并行程序中的同步
  4. px像素单位与IOS像素单位的换算
  5. c++ 利用容器vector动态的定义二维数组
  6. LA5059 Playing With Stones
  7. 【BZOJ2423】[HAOI2010]最长公共子序列 DP
  8. 区分兼容IE6/IE7/IE8/IE9/FF的CSS HACK写法
  9. 每日集成CruiseControl.NET + SVN + Msbuild + NAnt
  10. SignalR循序渐进(三)简易的集群通讯组件