题目链接

luogu P1361 小M的作物

题解

源汇点为A,B

向种子连边,容量为价值,每个种子能与A或B联通,考虑最小割

用建边的总流量减去最小割就是答案

相同利益的时候新建节点,由额外利益构成群体向新建节点连边容量INF,新建节点向对应(源\汇)连对应额外利益的边

开始只新开了一个节点连了个双向边orz

代码

// luogu-judger-enable-o2
#include<queue>
#include<cstdio>
#include<cstring>
#include<algorithm>
using std::queue;
using std::min;
#define INF 0x7fffffff
const int maxn = 770000;
inline int read() {
int x=0;char c=getchar();
while(c<'0'||c>'9') c=getchar();
while(c<='9'&&c>='0') x=x*10+c-'0',c=getchar();
return x;
}
int n,S,T,sum,A[maxn],B[maxn];
struct node{
int v,flow,next;
}edge[maxn];int head[maxn],num=1;
inline void add_edge(int u,int v,int flow) {
edge[++num].v=v;edge[num].flow=flow,edge[num].next=head[u];head[u]=num;
edge[++num].v=u;edge[num].flow=0;edge[num].next=head[v];head[v]=num;
}
int cur[maxn],lev[maxn];
bool spfa() {
memset(lev,-1,sizeof lev);
memcpy(cur,head,sizeof head);
queue<int>que;
que.push(S);lev[S]=0;
while(!que.empty()) {
int u=que.front();que.pop();
for(int i=head[u];i;i=edge[i].next) {
int v=edge[i].v;
if(edge[i].flow>0&&lev[v]<0) {
lev[v]=lev[u]+1;que.push(v);
}
}
}
if(lev[T]!=-1)return true;
else return false;
}
int dfs(int now,int flow) {
if(now==T)return flow;
int rest=0,delta;
for(int &i=cur[now];i;i=edge[i].next) {
int v=edge[i].v;
if(lev[v]==lev[now]+1&&edge[i].flow>0) {
delta=dfs(v,min(flow-rest,edge[i].flow));
if(delta) {
edge[i].flow-=delta;
edge[i^1].flow+=delta;
rest+=delta;if(rest==flow)break;
}
}
}
if(rest==flow)lev[now]=-1;
return rest;
}
int ans=0;
void dinic() {
while(spfa())
ans-=dfs(S,INF);
}
int main() {
n=read();
S=0,T=n+1;
for(int a,i=1;i<=n;++i)
add_edge(S,i,A[i]=read()),ans+=A[i];
for(int a,i=1;i<=n;++i)
add_edge(i,T,B[i]=read()),ans+=B[i];
int m=read();
for(int k,c1,c2,i=1;i<=m;++i) {
k=read();c1=read(),c2=read();
for(int a,j=1;j<=k;++j)
add_edge(a=read(),T+i+m,INF),add_edge(T+i,a,INF);
add_edge(S,T+i,c1),add_edge(T+i+m,T,c2);
ans+=c1+c2;
}
dinic();
printf("%d\n",ans);
return 0;
}

最新文章

  1. 【转载】写一个js库需要怎样的知识储备和技术程度?
  2. KnockoutJS 3.X API 第六章 组件(2) 组件注册
  3. chrome 不支持window.webkitNotifications.createNotification消息通知API了
  4. Hadoop在eclipse中的配置
  5. linux初始化配置---主机名、关闭防火墙、关闭selinux
  6. 【翻译】Kinect v2程序设计(C++) BodyIndex篇
  7. 在CentOS下安装Redis
  8. Flex Alert的匿名回调函数如何得到正确的this
  9. 关于生成缩略图及水印图片时出现GDI+中发生一般性错误解决方法
  10. Maven 插件开发(一)
  11. 细说PHP中strlen和mb_strlen的区别
  12. Request Connection: Remote Server @ 192.229.145.200:80
  13. xampp安装时mysql报错
  14. 将已有项目导入Gitlab
  15. 原生化:AnDevCon 2014 McVeigh 的主题演讲
  16. Git使用方法记录(一)
  17. servlet 监听器分类
  18. SDOI2019R1游记
  19. 使用HTML meta no-cache标签来禁用缓存
  20. Springboot 实现api校验和登录验证

热门文章

  1. 浅谈==和equals的区别
  2. (原)Unreal 渲染模块引言Temp
  3. win10 ubuntu16双系统安装教程
  4. 剑指offer-替换空格02
  5. 搭建springmvc项目404,没扫描到包
  6. php session 测试
  7. 在ESXi使用esxcli命令強制关闭VM
  8. Spring Cloud配置文件加载优先级简述
  9. Avoiding memory leaks in POSIX thread programming, 多线程避免内存泄漏
  10. bzoj 3289 Mato的文件管理 区间逆序对数(离线) 莫队