题目大意:

https://www.luogu.org/problemnew/show/P3410

题解 https://www.cnblogs.com/2020pengxiyue/p/9463055.html

源点s到各任务的边权为利益

各任务需要的职工到汇点t的边权为花费

当某一任务的 利益>=花费 时,求得的最大流为完成该任务需要的花费(1)

当某一任务的 利益<花费 时,求得的最大流为完成该任务所得的利益(2)

用总的利益减去最大流得到的

对(1)来说得到的是该任务的纯利

对(2)来说得到的是0 即不做该任务

#include <bits/stdc++.h>
#define INF 0x3f3f3f3f
#define LL long long
using namespace std; const int N=; int n,m,w[N],p[N];
vector <int> vec[N]; struct MAXFLOW {
struct NODE { int to,cap,rev; };
vector <NODE> G[N];
int lev[N], iter[N];
int s,t;
void addE(int u,int v,int cap) {
G[u].push_back((NODE){v,cap,G[v].size()});
G[v].push_back((NODE){u,,G[u].size()-});
}
void BFS(int s) {
memset(lev,-,sizeof(lev));
queue<int>q;
q.push(s); lev[s]=;
while(!q.empty()) {
int u=q.front(); q.pop();
for(int i=;i<G[u].size();i++) {
NODE &v=G[u][i];
if(v.cap> && lev[v.to]<)
lev[v.to]=lev[u]+, q.push(v.to);
}
}
}
int DFS(int u,int t,int f) {
if(u==t) return f;
for(int &i=iter[u];i<G[u].size();i++) {
NODE &v=G[u][i];
if(v.cap> && lev[u]<lev[v.to]) {
int d=DFS(v.to,t,min(f,v.cap));
if(d>) {
v.cap-=d;
G[v.to][v.rev].cap+=d;
return d;
}
}
}
return ;
}
int maxFlow() {
int flow=;
while() {
BFS(s);
if(lev[t]<) return flow;
memset(iter,,sizeof(iter));
while() {
int f=DFS(s,t,INF);
if(f>) flow+=f;
else break;
}
}
}
}F; int main()
{
while(~scanf("%d%d",&n,&m)) {
int sum=, tmp;
for(int i=;i<=n;i++) {
scanf("%d",&p[i]);
sum+=p[i]; vec[i].clear();
while(~scanf("%d",&tmp)&&tmp)
vec[i].push_back(tmp);
}
for(int i=;i<=m;i++) scanf("%d",&w[i]);
int node=n+m;
F.s=+node, F.t=+node;
for(int i=;i<=n;i++) {
F.addE(F.s,i,p[i]);
for(int j=;j<vec[i].size();j++)
F.addE(i,vec[i][j]+n,INF);
}
for(int i=n+;i<=n+m;i++) F.addE(i,F.t,w[i-n]);
printf("%d\n",sum-F.maxFlow());
} return ;
}

P3410 /// 最大流最小割的更多相关文章

  1. hiho 第116周,最大流最小割定理,求最小割集S,T

    小Hi:在上一周的Hiho一下中我们初步讲解了网络流的概念以及常规解法,小Ho你还记得内容么? 小Ho:我记得!网络流就是给定了一张图G=(V,E),以及源点s和汇点t.每一条边e(u,v)具有容量c ...

  2. hihocoder 网络流二·最大流最小割定理

    网络流二·最大流最小割定理 时间限制:10000ms 单点时限:1000ms 内存限制:256MB 描述 小Hi:在上一周的Hiho一下中我们初步讲解了网络流的概念以及常规解法,小Ho你还记得内容么? ...

  3. [HihoCoder1378]网络流二·最大流最小割定理

    思路: 根据最大流最小割定理可得最大流与最小割相等,所以可以先跑一遍EdmondsKarp算法.接下来要求的是经过最小割切割后的图中$S$所属的点集.本来的思路是用并查集处理所有前向边构成的残量网络, ...

  4. HDU 1569 方格取数(2)(最大流最小割の最大权独立集)

    Description 给你一个m*n的格子的棋盘,每个格子里面有一个非负数. 从中取出若干个数,使得任意的两个数所在的格子没有公共边,就是说所取数所在的2个格子不能相邻,并且取出的数的和最大.   ...

  5. FZU 1844 Earthquake Damage(最大流最小割)

    Problem Description Open Source Tools help earthquake researchers stay a step ahead. Many geological ...

  6. 【codevs1907】方格取数3(最大流最小割定理)

    网址:http://codevs.cn/problem/1907/ 题意:在一个矩阵里选不相邻的若干个数,使这些数的和最大. 我们可以把它看成一个最小割,答案就是矩阵中的所有数-最小割.先把矩阵按国际 ...

  7. 紫书 例题 11-12 UVa 1515 (最大流最小割)

    这道题要分隔草和洞, 然后刘汝佳就想到了"割"(不知道他怎么想的, 反正我没想到) 然后就按照这个思路走, 网络流建模然后求最大流最小割. 分成两部分, S和草连, 洞和T连 外围 ...

  8. HDU-4289-Control(最大流最小割,拆点)

    链接: https://vjudge.net/problem/HDU-4289 题意: You, the head of Department of Security, recently receiv ...

  9. 牛客暑期第六场G /// 树形DP 最大流最小割定理

    题目大意: 输入t,t个测试用例 每个测试用例输入n 接下来n行 输入u,v,w,树的无向边u点到v点权重为w 求任意两点间的最大流的总和 1.最大流最小割定理 即最大流等于最小割 2.无向树上的任意 ...

随机推荐

  1. 使用postman做接口测试----柠檬不萌!

    目录 一.GET和POST请求的区别 二.http协议 1.http请求分为两个部分 2.http状态码 三.使用postman测试HTTP接口 1.请求方式:get 2.请求方式:post 3.请求 ...

  2. Cocos2d-x之Director

    |   版权声明:本文为博主原创文章,未经博主允许不得转载. Director类简介 在Cocos2d-x-3.x引擎中,采用节点树形结构来管理游戏对象,一个游戏可以划分为不同的场景,一个场景又可以分 ...

  3. shell eval命令

    1. eval command-line 其中command-line是在终端上键入的一条普通命令行.然而当在它前面放上eval时,其结果是shell在执行命令行之前扫描它两次.如: pipe=&qu ...

  4. markdown_TestOne

    这个是我写的一个markdown尝试 1.2 dafsdfeasdfaefasdfase afsdfasdfefasdfeadfasdfe

  5. Python测试代理ip是否有效

    方式一: 通过icanhazip.com返回的ip地址进行检测 import requests '''代理IP地址(高匿)''' proxy = { 'http': 'http://117.85.10 ...

  6. Android开发:图文分析 Handler通信机制 的工作原理

    前言 在Android开发的多线程应用场景中,Handler机制十分常用 下面,将图文详解 Handler机制 的工作原理 目录 1. 定义 一套 Android 消息传递机制 2. 作用 在多线程的 ...

  7. 2018-8-10-win10-UWP-button

    title author date CreateTime categories win10 UWP button lindexi 2018-08-10 19:16:53 +0800 2018-2-13 ...

  8. sqldeveloper全部导出

    点击Tools--Export User Objects 这种方式可以导出当前用户拥有的所有对象,包括表.视图.触发器.同义词等等,对于表,只能导出表结构(建表语句),不能导出数据, 选中要导出的对象 ...

  9. Mybatis调用Oracle中的存储过程和function

    一.Mybatis调用存储过程 1 在数据库中创建以下的存储过程create or replace procedure pro_hello(p_user_name in varchar2,p_resu ...

  10. java中设置http响应头控制浏览器禁止缓存当前文档内容

    response.setDateHeader("expries", -1); response.setHeader("Cache-Control", " ...