最大流 这题有很多起点和终点 在取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;
}

最新文章

  1. Combinations
  2. python基础05 if选择
  3. svn清理失败且路径显示乱码
  4. [hihoCoder#1381]Little Y&#39;s Tree
  5. 十八、mysql 内存优化 之 myisam
  6. 6.MVC框架开发(文件上传)
  7. 【LA 5713 】 Qin Shi Huang&#39;s National Road System (MST)
  8. POJ 2152 Fire
  9. Flex Robotlegs
  10. Tomcat 笔记-配置虚拟目录
  11. 尤克里里 ukulele 单板 非kaka tom uma
  12. mysql更新字段内容
  13. Flask websocket
  14. VUE-010-通过声明式导航 router-link 传递 params 参数(路由 name 识别,请求链接不显示参数传递)
  15. 对于Linux内核执行过程的理解(基于fork、execve、schedule等函数)
  16. MySql的创建时间和修改时间
  17. ubuntun与qt下载地址
  18. 【网络编程】服务端产生大量的close_wait状态的进程分析
  19. Python获取系统音量
  20. ASP.NET MVC下实现前端视图页的Session

热门文章

  1. D - 楼下水题(kmp+Manacher)
  2. C++ 经常使用类 string类
  3. 拿出来分享了!VIP珍藏!!!全网最齐全的 DEDECMS模板 全盘下载地址列表!没有你找不到的!
  4. 对象作为返回值类型&amp;&amp;链式编程
  5. IOC容器初始化——BeanDefinition的Resource定位
  6. Android 开发技巧
  7. python中的异常如何处理
  8. 配置 .vimrc 解决 Vim / gVim 在中文 Windows 下的字符编码问题
  9. c 占位符
  10. xml校验问题