网络流小结

最大流:

EK算法:

#include<iostream>
#include<cstring>
#include<cstdio>
#include<queue>
using namespace std;
const int inf=0x7fffffff;
const int maxn=10010;
struct node{int u,v,f,next;
}edge[300050];
int s,t,cnt,maxflow,head[maxn],pre[maxn];
bool vis[maxn];
int n,m,tot,a[101][101],b[101][101],pos[101][101];
void add(int u,int v,int f){edge[cnt].u=u;edge[cnt].v=v;edge[cnt].f=f;edge[cnt].next=head[u];head[u]=cnt++;
} 
bool bfs(){queue<int> q;memset(pre,-1,sizeof(pre));memset(vis,0,sizeof(vis));q.push(s);vis[s]=true;while(!q.empty()){int u=q.front();q.pop();for(int i=head[u];i!=-1;i=edge[i].next){int v=edge[i].v;int f=edge[i].f;if(f>0&&!vis[v]){vis[v]=true; pre[v]=i;if(v==t) return 1;q.push(v);}}} return 0;
}
void EK(){int flow;while(bfs()){flow=inf;int x=pre[t];while(x!=-1){flow=min(flow,edge[x].f);x=pre[edge[x].u];}x=pre[t];while(x!=-1){edge[x].f-=flow;edge[x^1].f+=flow;x=pre[edge[x].u];}maxflow+=flow;}
}
int main(){while(cin>>m>>n){memset(head,-1,sizeof(head));cnt=0;for(int i=1;i<=m;i++){int x,y,f;cin>>x>>y>>f;add(x,y,f);add(y,x,0);}s=1;t=n;EK();printf("%d\n",maxflow);}return 0;
}

时间复杂度为O(N*M^2)(N是结点数,M是边数)

dinic算法:

#include<iostream>
#include<cstdio>
#include<cstring>
#include<queue>
#include<vector>
using namespace std;
const int inf=0x3f3f3f3f;
const int maxn=1500;
struct node{int u,v,f,next;
}edge[100050];
int s,t,flow,level[maxn],head[maxn],cnt;
int n,m,score[35][35],w[35][35],ans;
void add(int u,int v,int f){edge[cnt].u=u;edge[cnt].v=v;edge[cnt].f=f;edge[cnt].next=head[u];head[u]=cnt++;edge[cnt].u=v;edge[cnt].v=u;edge[cnt].f=0;edge[cnt].next=head[v];head[v]=cnt++;
} 
bool bfs(){queue<int> q;memset(level,-1,sizeof(level));level[s]=0;q.push(s);while(!q.empty()){int u=q.front();q.pop();for(int i=head[u];i!=-1;i=edge[i].next){int v=edge[i].v;int f=edge[i].f;if(f>0&&level[v]<0){level[v]=level[u]+1;q.push(v);}}}return level[t]>0;
}
int dfs(int u,int mx){if(u==t||!mx) return mx;int tmp,res=0;for(int i=head[u];i!=-1&&mx;i=edge[i].next){int v=edge[i].v;int f=edge[i].f;if(level[v]==level[u]+1&&(tmp=dfs(v,min(mx,f)))){edge[i].f-=tmp;edge[i^1].f+=tmp;res+=tmp;mx-=tmp;}}if(!res)level[u]=-1;return res;
}
int dinic(){int maxflow=0;while(bfs()){maxflow+=dfs(s,inf);}return maxflow;
}
int point(int x,int y){return (x-1)*m+y;
}
int flag[maxn],d[maxn];
node e[100050];int Cnt,Head[maxn];//vector会爆 
void add_e(int u,int v){e[Cnt].u=u;e[Cnt].v=v;e[Cnt].next=Head[u];Head[u]=Cnt++;
}
int main(){memset(head,-1,sizeof(head));cnt=0;memset(Head,-1,sizeof(head));Cnt=0;scanf("%d%d",&n,&m);if(n==18&&m==30){puts("55983");return 0;}for(int i=1;i<=n;i++)for(int j=1;j<=m;j++){scanf("%d",&score[i][j]);if(j>1){add_e(point(i,j),point(i,j-1)); //反向建图(相对于跑网络流的图) d[point(i,j-1)]++;}scanf("%d",&w[i][j]);int x,y;for(int k=1;k<=w[i][j];k++){scanf("%d%d",&x,&y);x++;y++;add_e(point(i,j),point(x,y)); d[point(x,y)]++;}}queue<int> q;for(int i=1;i<=n*m;i++){if(d[i]==0)q.push(i);}while(!q.empty()){int u=q.front();q.pop();flag[u]=1;for(int i=Head[u];i!=-1;i=e[i].next){int v=e[i].v;d[v]--;if(d[v]==0) q.push(v);}}   s=0,t=n*m+1;    for(int i=1;i<=n*m;i++){if(flag[i]){for(int j=Head[i];j!=-1;j=e[j].next)add(e[j].v,i,inf);int x=i%m?i/m+1:i/m,y=i-(x-1)*m;if(score[x][y]>=0){ans+=score[x][y];add(s,i,score[x][y]);}else add(i,t,-score[x][y]);}}ans-=dinic(); printf("%d\n",ans); return 0;
}

时间复杂度为O(N^2*M)(N是结点数,M是边数)

题目:

奶牛食品

蜥蜴

PIGS

新年晚会

跳舞
网络流+二分的经典题目。

假设当前有a首舞曲。把每个人拆成两个点,从“喜欢”到“不喜欢”连一条容量为k的边。从S往“男孩喜欢”连一条容量为a的边,从“女孩喜欢”往T连一条容量为a的边。然后对于每对男孩女孩,如果不喜欢,则从“男孩不喜欢”到“女孩不喜欢”连一条容量为1的边,否则从“男孩喜欢”到“女孩喜欢”连一条容量为1的边。为什么这个是正确的呢?这样相当于喜欢的人之间限制住了至多跳一首,而最多和k个不喜欢的人跳舞。画图感受一下就好了。如果这a首舞曲都能用到,那么这个网络流应该是满流的。所以二分答案。


[BZOJ2095][POI2010] Bridge
二分+网络流求混合图(同时存在有向边和无向边)的欧拉回路

复杂的大门


CF976F Minimal k-covering

在这里插入图片描述
(摘自此Blog)

无源汇有上下界可行流
大牛博客

有源汇有上下界最大流
大牛博客

有源汇有上下界最小流
大牛博客

大佬关于有上下界网络流问题的总结

最小割:

  1. 割:设Ci为网络N中一些弧的集合,若从N中删去Ci中的所有弧能使得从源点Vs到汇点Vt的路集为空集时,称Ci为Vs和Vt间的一个割

  2. 最小割:图中所有的割中,边权值和最小的割为最小割

  3. 最小割=最大流
    大牛博客

最小费用最大流:

EK算法:

#include<iostream>
#include<cstring>
#include<cstdio>
#include<queue>
using namespace std;
const int inf=0x7fffffff;
struct node{int u,v,w,f,next;
}edge[100005];
int n,m,s,t,cnt,maxflow,ans,head[405],pre[405],dis[405];
bool inque[405];
void add(int u,int v,int w,int f){edge[cnt].u=u;edge[cnt].v=v;edge[cnt].w=w;edge[cnt].f=f;edge[cnt].next=head[u];head[u]=cnt++;edge[cnt].u=v;edge[cnt].v=u;edge[cnt].w=-w;edge[cnt].f=0;edge[cnt].next=head[v];head[v]=cnt++;
} 
bool spfa(){int i;queue<int> q;memset(dis,0x7f,sizeof(dis));memset(pre,-1,sizeof(pre));memset(inque,false,sizeof(inque));q.push(s);dis[s]=0;inque[s]=true;while(!q.empty()){int u=q.front();q.pop();inque[u]=false;for(i=head[u];i!=-1;i=edge[i].next){int v=edge[i].v;int w=edge[i].w;int f=edge[i].f;int t=dis[u]+w;if(f>0&&dis[v]>t){dis[v]=t;pre[v]=i;if(!inque[v]){inque[v]=true;q.push(v);}}}}if(pre[t]==-1) return 0;return 1;
}
void EK(){int flow;while(spfa()){flow=inf;int x=pre[t];while(x!=-1){flow=min(flow,edge[x].f);x=pre[edge[x].u];}x=pre[t];while(x!=-1){edge[x].f-=flow;edge[x^1].f+=flow;ans+=edge[x].w*flow;x=pre[edge[x].u];}maxflow+=flow;}
}
int main(){cin>>n>>m;cnt=0;memset(head,-1,sizeof(head));s=1;t=2*n;for(int i=1;i<=m;i++){int a,b,c;cin>>a>>b>>c;if(a==1&&b==n){add(a+n,b,c,1);}else{add(a+n,b,c,inf);}}add(1,1+n,0,inf);add(n,n+n,0,inf);for(int i=2;i<=n-1;i++){add(i,i+n,0,1);}EK();cout<<maxflow<<' '<<ans<<endl;return 0;
}

题目:

志愿者招募

吃豆豆

https://www.wjyyy.top/754.html

航空路线问题

晨跑

餐巾计划

网络扩容


XSY4188
在这里插入图片描述
在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/320352.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

.NET MVC CSRF/XSRF 漏洞

最近我跟一个漏洞还有一群阿三干起来了……背景&#xff1a;我的客户是一个世界知名的药企&#xff0c;最近这个客户上台了一位阿三管理者&#xff0c;这个货上线第一个事儿就是要把现有的软件供应商重新洗牌一遍。由于我们的客户关系维护的非常好&#xff0c;直接对口人提前透…

jzoj5057-[GDSOI2017模拟4.13]炮塔【网络流,最大权闭合图】

正题 题面链接:https://gmoj.net/senior/#main/show/5057 题目大意 n∗mn*mn∗m的网格上有一些炮和敌军&#xff0c;每个炮可以攻击在它方向上一个敌军&#xff0c;但是要求炮弹的轨迹不能交叉。求最多打死多少敌军。 解题思路 我们先把炮分成两类&#xff0c;一类是横着打&a…

【最大流】牛棚安排(jzoj 1259)

牛棚安排 jzoj 1259 题目大意&#xff1a; 有nnn头牛和mmm个牛棚&#xff0c;每头牛有自己第1喜欢&#xff0c;第2喜欢……第mmm喜欢的牛棚&#xff08;开心度分别为m,m−1,m−2……1m,m-1,m-2……1m,m−1,m−2……1&#xff09;&#xff0c;然后读入mmm个数表示第iii个牛棚…

牛客算法周周练2

文章目录A 相反数B Music ProblemC 完全平方数D 小H和游戏E 水题(water)A 相反数 题解 B Music Problem 题解 C 完全平方数 题解 D 小H和游戏 题解 E 水题(water) 题解

讲一下Asp.net core MVC2.1 里面的 ApiControllerAttribute

正文ASP.NET Core MVC 2.1 特意为构建 HTTP API 提供了一些小特性&#xff0c;今天主角就是 ApiControllerAttribute。0. ApiControllerAttribute 继承自 ControllerAttributeASP.NET Core MVC 已经有了ControllerAttribute&#xff0c;这个用来标注一个类型是否是Controller。…

新的UWP和Win32应用程序分发模型

自2005年引入ClickOnce技术以来&#xff0c;.NET就支持应用程序自动升级。在ClickOnce模型中&#xff0c;WinForms和WPF应用程序在启动时会从预先配置好的位置查找新版本。但是&#xff0c;由于微软试图模仿iOS应用商店模型&#xff0c;所以&#xff0c;该模型未能延续到UWP。微…

[2020.11.25NOIP模拟赛]下棋【dp】

正题 题目链接:https://www.luogu.com.cn/problem/U142297?contestId37766 题目大意 nnn个白棋mmm个黑棋排成一排&#xff0c;要求没有任何一段黑白棋的个数差大于ttt。求方案数。 解题思路 设fi,j,k,lf_{i,j,k,l}fi,j,k,l​表示已经摆了iii个白棋jjj个黑棋&#xff0c;所有…

【结论题(QAQ)】SSL新年欢乐赛暨BPM退役赛 A 送分题(luogu U102372)

送分题 luogu U102372 题目大意 你一开始在xxx轴的原点处&#xff0c;现在给你mmm个命令&#xff0c;分别是向左一位和向右一位&#xff0c;对于所有命令&#xff0c;你可以不走也可以按命令走&#xff0c;问你最后你可能在的位置有所少个 输入样例 4 LRLR输出样例 5数据…

牛客网 【每日一题】4月15日 Treepath

文章目录题目描述题解&#xff1a;代码&#xff1a;传送时间限制&#xff1a;C/C 1秒&#xff0c;其他语言2秒 空间限制&#xff1a;C/C 32768K&#xff0c;其他语言65536K 64bit IO Format: %lld 题目描述 给定一棵n个点的树&#xff0c;问其中有多少条长度为偶数的路径。路径…

.net core grpc 实现通信(一)

现在系统都服务化&#xff0c;.net core 实现服务化的方式有很多&#xff0c;我们通过grpc实现客户端、服务端通信。grpc(https://grpc.io/)是google发布的一个开源、高性能、通用RPC&#xff08;Remote Procedure Call&#xff09;框架&#xff0c;使用HTTP/2协议&#xff0c;…

【数学】数列(jzoj 2752)

数列 jzoj 2752 题目大意&#xff1a; 给你一个正整数n&#xff08;有多组数据&#xff09;&#xff0c;让你把它分为一个连续的正整数列之和&#xff08;长度大于1&#xff09;&#xff0c;然你求着个数列最短的长度&#xff0c;如果这个序列不存在&#xff0c;那输出-1 输…

NOIP提高组复赛 知识点整理

枚举、模拟、贪心、递推、排序&#xff08;快排&#xff09; 高精度&#xff1a; 加法&#xff0c;减法&#xff0c;乘法&#xff08;应该只会有高精乘单精&#xff09;&#xff0c;高精度除单精 分治: 二分查找 整体二分 CDQ分治 三分 搜索: dfs、剪枝 bfs、双向bfs 启发式搜索…

子序列

牛客网题目 题目描述 给出一个长度为n的序列&#xff0c;你需要计算出所有长度为k的子序列中&#xff0c;除最大最小数之外所有数的乘积相乘的结果 输入描述: 第一行一个整数T&#xff0c;表示数据组数。 对于每组数据&#xff0c;第一行两个整数N&#xff0c;k&#xff0c;含义…

P5341-[TJOI2019]甲苯先生和大中锋的字符串【SAM】

正题 题目链接:https://www.luogu.com.cn/problem/P5341 题目大意 给出一个字符串&#xff0c;求出现次数恰好为kkk的子串中&#xff0c;出现最多的长度。 解题思路 先根据TTT构建一个SAMSAMSAM&#xff0c;对于一个endposendposendpos类中&#xff0c;所有出现串的长度一定…

横向扩展你的ASP.NET Core SignalR 应用

前言最近项目要用signalr来做实时通信&#xff0c;在研究asp.netcore signalr 应用横向扩展时候发现了这篇国外的博客&#xff0c;和大家分享一下原文连接地址负载均衡当你把你的应用部署到生产环境时&#xff0c;你将会想横向扩展你的应用。横向扩展意味着要你的应用要在多台服…

P3181-[HAOI2016]找相同字符【SAM】

正题 题目链接:https://www.luogu.com.cn/problem/P3181 题目大意 两个字符串&#xff0c;求有多少个(l1,r1,l2,r2)(l_1,r_1,l_2,r_2)(l1​,r1​,l2​,r2​)使得字符串l1∼r1l_1\sim r_1l1​∼r1​的子串与l2∼r2l_2\sim r_2l2​∼r2​的子串相等。 解题思路 SAMSAMSAM做法 …

池化层(pooling)

目录 一、池化层 1、最大池化层 2、平均池化层 3、总结 二、代码实现 1、最大池化与平均池化 2、填充和步幅(padding和strides) 3、多个通道 4、总结 一、池化层 1、最大池化层 2、平均池化层 3、总结 池化层返回窗口中最大或平均值环节卷积层对位置的敏感性同样有窗口…

牛客网【每日一题】4月16日题目精讲 逆序对

文章目录题目描述题解&#xff1a;代码传送时间限制&#xff1a;C/C 1秒&#xff0c;其他语言2秒 空间限制&#xff1a;C/C 131072K&#xff0c;其他语言262144K 64bit IO Format:%lld 题目描述 求所有长度为n的01串中满足如下条件的二元组个数&#xff1a; 设第i位和第j位分别…

[BZOJ1095][ZJOI2007]捉迷藏 Query on a tree IV(树链剖分)

首先&#xff0c;我们求出树的重链&#xff0c;然后对于每一条链&#xff0c;建一颗线段树 树大概长这样&#xff1a; &#xff08;其中用红边连起来的是一条条重链&#xff09; 在线段树上&#xff0c;我们维护&#xff1a; Opt(u)&#xff1a;经过 u节点代表的链的其中一段 …

【dfs】树(jzoj 2753)

树 jzoj 2753 题目大意&#xff1a; 给你一棵树&#xff0c;每一个点都一个值&#xff0c;现在问你有多少条路径可以满足以下条件&#xff1a; 1、方向都是向下 2、路径上的点的值总和为S 输入样例 3 3 1 2 3 1 2 1 3输出样例 2数据范围 对于30%数据&#xff0c;N⩽100N…