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.无向树上的任意 ...
随机推荐
- Tomcat启动脚本(3)setclasspath.bat
@echo off rem Licensed to the Apache Software Foundation (ASF) under one or more rem contributor lic ...
- neo4j简单学习
阅读更多 背景 最近在一些论坛或者新闻里看到了neo4j,一种擅长处理图形的数据库. 据说非常适合做一些join关系型的查询,所以抽空也看了下相关文档,给自己做个技术储备. 过程 深入学习之前,先在网 ...
- pytest_参数化之3*3
import pytesttest_user_data1=[{'user':'linda','password':'888888'}, {'user':'servenruby','password': ...
- MyBatis笔记二:配置
MyBatis笔记二:配置 1.全局配置 1.properites 这个配置主要是引入我们的 properites 配置文件的: <properties resource="db.pr ...
- JSP界面引用百度地图获取坐标
需求: 需要在JSP界面上引用百度地图,文本框中输入地址之后,自动拿到在百度地图上的经纬度 解决步骤: 1.引入百度地图api: head中进行引用<script type="text ...
- celery使用多队列
生产者: 文件1: 定义任务 #!/usr/bin/env python3 # coding: utf-8 from celery import Celery import settings pw = ...
- 项目案例之GitLab的数据迁移
项目案例之GitLab的数据迁移 链接:https://pan.baidu.com/s/1CgaEv12cwfbs5RxcNpxdAg 提取码:fytm 复制这段内容后打开百度网盘手机App,操作更方 ...
- LinkedBlockingQueue 学习
LinkedBlockingQueue 链表队列,其元素构成为: static class Node<E> { E item; Node<E> next; Node(E x) ...
- 前端学习(二)css样式笔记(笔记)
background-image:url(img/xiaofeiji.jpg)背景图:url(图片路径):(背景图默认平铺) background-repeat:repeat-x/repeat-y/n ...
- Metrics介绍和Spring的集成(转)
转自:http://blog.csdn.net/smallnest/article/details/38491507 http://colobu.com/2014/08/08/Metrics-and- ...