UVa 10330 Power Transmission / 最大流
2024-09-12 19:20:20
最大流 这题有很多起点和终点 在取2个点(0和n+1) 作为唯一的起点和终点
此外每个点也有容量限制 建图时每条边上的容量为这条边和2个端的容量的最小值 然后EK就行
#include <cstdio>
#include <cstring>
#include <algorithm>
#include <queue>
using namespace std;
const int MAX = 110;
int num[MAX];
int a[MAX];
int cap[MAX][MAX];
int flow[MAX][MAX];
int p[MAX];
int n,m,b,d;
int f;
void EK()
{
queue <int> q;
memset(flow,0,sizeof(flow));
f = 0;
while(1)
{
memset(a,0,sizeof(a));
a[0] = 999999999;
q.push(0);
while(!q.empty())
{
int u = q.front();
q.pop();
for(int v = 0; v <= n+1; v++)
{
if(!a[v] && cap[u][v] > flow[u][v])
{
p[v] = u;
q.push(v);
a[v] = min(a[u],cap[u][v] - flow[u][v]);
}
}
}
if(a[n+1] == 0)
break;
for(int u = n+1; u; u = p[u])
{
flow[p[u]][u] += a[n+1];
flow[u][p[u]] -= a[n+1];
}
f += a[n+1];
}
}
int main()
{
int i,x,y,z;
while(scanf("%d",&n)!=EOF)
{
memset(cap,0,sizeof(cap));
for(i = 1;i <= n; i++)
scanf("%d",&num[i]);
scanf("%d",&m);
while(m--)
{
scanf("%d %d %d",&x,&y,&z);
cap[x][y] = z;
cap[x][y] = min(cap[x][y],min(num[x],num[y]));
}
scanf("%d %d",&b,&d);
while(b--)
{
scanf("%d",&x);
cap[0][x] = num[x];
}
while(d--)
{
scanf("%d",&x);
cap[x][n+1] = num[x];
}
EK();
printf("%d\n",f);
}
return 0;
}
最新文章
- Combinations
- python基础05 if选择
- svn清理失败且路径显示乱码
- [hihoCoder#1381]Little Y&#39;s Tree
- 十八、mysql 内存优化 之 myisam
- 6.MVC框架开发(文件上传)
- 【LA 5713 】 Qin Shi Huang&#39;s National Road System (MST)
- POJ 2152	 Fire
- Flex Robotlegs
- Tomcat 笔记-配置虚拟目录
- 尤克里里 ukulele 单板 非kaka tom uma
- mysql更新字段内容
- Flask websocket
- VUE-010-通过声明式导航 router-link 传递 params 参数(路由 name 识别,请求链接不显示参数传递)
- 对于Linux内核执行过程的理解(基于fork、execve、schedule等函数)
- MySql的创建时间和修改时间
- ubuntun与qt下载地址
- 【网络编程】服务端产生大量的close_wait状态的进程分析
- Python获取系统音量
- ASP.NET MVC下实现前端视图页的Session