P3410 /// 最大流最小割
题目大意:
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 /// 最大流最小割的更多相关文章
- hiho 第116周,最大流最小割定理,求最小割集S,T
小Hi:在上一周的Hiho一下中我们初步讲解了网络流的概念以及常规解法,小Ho你还记得内容么? 小Ho:我记得!网络流就是给定了一张图G=(V,E),以及源点s和汇点t.每一条边e(u,v)具有容量c ...
- hihocoder 网络流二·最大流最小割定理
网络流二·最大流最小割定理 时间限制:10000ms 单点时限:1000ms 内存限制:256MB 描述 小Hi:在上一周的Hiho一下中我们初步讲解了网络流的概念以及常规解法,小Ho你还记得内容么? ...
- [HihoCoder1378]网络流二·最大流最小割定理
思路: 根据最大流最小割定理可得最大流与最小割相等,所以可以先跑一遍EdmondsKarp算法.接下来要求的是经过最小割切割后的图中$S$所属的点集.本来的思路是用并查集处理所有前向边构成的残量网络, ...
- HDU 1569 方格取数(2)(最大流最小割の最大权独立集)
Description 给你一个m*n的格子的棋盘,每个格子里面有一个非负数. 从中取出若干个数,使得任意的两个数所在的格子没有公共边,就是说所取数所在的2个格子不能相邻,并且取出的数的和最大. ...
- FZU 1844 Earthquake Damage(最大流最小割)
Problem Description Open Source Tools help earthquake researchers stay a step ahead. Many geological ...
- 【codevs1907】方格取数3(最大流最小割定理)
网址:http://codevs.cn/problem/1907/ 题意:在一个矩阵里选不相邻的若干个数,使这些数的和最大. 我们可以把它看成一个最小割,答案就是矩阵中的所有数-最小割.先把矩阵按国际 ...
- 紫书 例题 11-12 UVa 1515 (最大流最小割)
这道题要分隔草和洞, 然后刘汝佳就想到了"割"(不知道他怎么想的, 反正我没想到) 然后就按照这个思路走, 网络流建模然后求最大流最小割. 分成两部分, S和草连, 洞和T连 外围 ...
- HDU-4289-Control(最大流最小割,拆点)
链接: https://vjudge.net/problem/HDU-4289 题意: You, the head of Department of Security, recently receiv ...
- 牛客暑期第六场G /// 树形DP 最大流最小割定理
题目大意: 输入t,t个测试用例 每个测试用例输入n 接下来n行 输入u,v,w,树的无向边u点到v点权重为w 求任意两点间的最大流的总和 1.最大流最小割定理 即最大流等于最小割 2.无向树上的任意 ...
随机推荐
- Django框架(二十八)—— Django缓存机制
目录 Django缓存机制 一.什么是缓存 二.Django的6中缓存方式及配置(只需要改配置文件) 1.开发调试缓存(此模式为开发调试使用,实际上不执行任何操作) 2.内存缓存(将缓存内容保存至内存 ...
- Synchronized 与 ReentrantLock 的区别!
来源:cnblogs.com/baizhanshi/p/7211802.html 之前栈长分享了重入锁的概念:<到底什么是重入锁,拜托,一次搞清楚!>,今天现来深入了解下 Synchron ...
- Sqlplus常用指令
一.ORACLE的启动和关闭1.在单机环境下2.在双机环境下二.Oracle数据库有哪几种启动方式1.startup nomount 非安装启动,这种方式启动下可执行:重建控制文件.重建数据库2.st ...
- zabbix添加对web页面url的状态监控
zabbix3.0.4添加对web页面url的状态监控 1.应用集配置 在配置—>主机中打开主机列表,选择需要添加监控主机的web,创建应用集 2.web监测配置 选择web场景,再单击右上角的 ...
- Neo4j基础入门
图数据库基础知识 图数据库以图这种数据结构为基础,可以保存任意种类的数据,以下图为基础,简单介绍Neo4j中的几个简单概念: 1.节点(Nodes) 表示图数据库的实体(entities),代表图数据 ...
- el-form-item内容过多,及弹窗框宽度属性show-overflow-tooltip设置
内容过多: :show-overflow-tooltip=true 宽度属性设置: .el-tooltip__popper{ max-width:30% }
- 停止node进程
运行vue-cli项目的时候经常出现端口号占用,npm run dev报错的信息, 此时可通过任务管理器粗暴的杀死node进程,也可以通过cmd检测占用某个端口的程序,进而杀死该进程,步骤如下: 1. ...
- Codeforces 1150D DP
题意:给你一个长度为n的字符串,有q次询问,每次询问会给字符串x的末尾添加一个字符y,或者删除字符串x末尾的字符,询问过后,要判断长度为n的字符串中是否有3个不重合的子序列,是这3个字符串. 思路:设 ...
- java是否是“美丽的”语言
java 学习 (jdk扫描 配置读取 服务器选项 )
- 【hihoCoder】每周一题(从week 220开始)
2018/9/17-2018/9/23 week 220 push button I 题目链接:https://hihocoder.com/contest/hiho220/problem/1 有N个 ...