[BZOJ1061] [Noi2008] 志愿者招募 (费用流)
Description
Input
Output
仅包含一个整数,表示你所设计的最优方案的总费用。
Sample Input
2 3 4
1 2 2
2 3 5
3 3 2
Sample Output
HINT
1 ≤ N ≤ 1000,1 ≤ M ≤ 10000,题目中其他所涉及的数据均 不超过2^31-1。
Source
Solution
设第$i$种志愿者的人数为$x_{i}$,那么我们有不等式:(以样例说明)
$x_{1}\geq2$
$x_{1}+x_{2}\geq3$
$x_{2}+x_{3}\geq4$
目标为最小化$z=2x_{1}+5x_{2}+2x_{3}$
欸这不是线性规划么,麻麻我不会单纯形
好吧我们用费用流做:
假设我们原来有$INF$个志愿者,然后每一天都会少几个志愿者,需要花钱招募。现要求每一天都有$INF$个志愿者。
然后就按改变后的题意建图:
源点向第一个点连$(INF,0)$的边,之后每一个点向后一个点连$(INF-P[i],0)$的边,第$m+1$个点作为汇点
之后对于每一个志愿者,我们从点$S[i]$到点$T[i]+1$连$(INF,C[i])$的边。
此时最大流必为$INF$,最小费用即为所求答案。
zkw费用流是什么。。。据说费用流不会卡EK算法
#include <bits/stdc++.h>
using namespace std;
typedef long long ll;
const ll INF = 1e18;
struct edge
{
int u, v, nxt;
ll w, c;
}e[];
queue<int> Q;
int n, etot = , fst[], fa[];
bool inq[];
ll ans, dis[]; void addedge(int u, int v, ll w, ll c)
{
e[++etot] = (edge){u, v, fst[u], w, c}, fst[u] = etot;
e[++etot] = (edge){v, u, fst[v], , -c}, fst[v] = etot;
} bool SPFA()
{
int u;
memset(dis, , sizeof(dis));
dis[n + ] = , Q.push(n + ), inq[n + ] = true;
while(!Q.empty())
{
u = Q.front(), Q.pop();
for(int i = fst[u]; i; i = e[i].nxt)
if(e[i].w && dis[e[i].v] > dis[u] + e[i].c)
{
dis[e[i].v] = dis[u] + e[i].c;
fa[e[i].v] = i;
if(!inq[e[i].v])
Q.push(e[i].v), inq[e[i].v] = true;
}
inq[u] = false;
}
if(dis[n + ] >= INF) return false;
return true;
} void Edmond_Karp()
{
ll w = INF;
for(int i = fa[n + ]; i; i = fa[e[i].u])
w = min(w, e[i].w);
for(int i = fa[n + ]; i; i = fa[e[i].u])
e[i].w -= w, e[i ^ ].w += w, ans += e[i].c * w;
} int main()
{
int m, u, v;
ll w;
cin >> n >> m;
addedge(n + , , INF, );
for(int i = ; i <= n; ++i)
{
cin >> w;
addedge(i, i + , INF - w, );
}
for(int i = ; i <= m; ++i)
{
cin >> u >> v >> w;
addedge(u, v + , INF, w);
}
while(SPFA())
Edmond_Karp();
cout << ans << endl;
return ;
}
[BZOJ1061] [Noi2008] 志愿者招募 (费用流)的更多相关文章
- BZOJ 1061: [Noi2008]志愿者招募 费用流
1061: [Noi2008]志愿者招募 题目连接: http://www.lydsy.com/JudgeOnline/problem.php?id=1061 Description 申奥成功后,布布 ...
- P3980 [NOI2008]志愿者招募 费用流 (人有多大胆地有多大产
https://www.luogu.org/problemnew/show/P3980 感觉费用流比网络流的图更难想到,要更大胆.首先由于日期是连续的,所以图中的点是横向排列的. 这道题有点绕道走的意 ...
- [NOI2008]志愿者招募 (费用流)
大意: $n$天, 第$i$天要$a_i$个志愿者. $m$种志愿者, 每种无限多, 第$i$种工作时间$[s_i,t_i]$花费$c_i$, 求最少花费. 源点$S$连第一天, 容量$INF$ 第$ ...
- P3980 [NOI2008]志愿者招募 (费用流)
题意:最多1000天 每天需要至少ai个工人施工 有10000种工人可以雇佣 每种工人可以工作si到ti天 雇佣一个的花费是ci 问怎样安排使得施工花费最少 思考:最直白的建模方式 就是每种工人可以和 ...
- Vijos1825 NOI2008 志愿者招募 费用流
Orz ByVoid大神的题解:https://www.byvoid.com/blog/noi-2008-employee/ 学习网络流建图的好题,不难想到线性规划的模型,不过利用模型的特殊性,结合网 ...
- [BZOJ1061][Noi2008]志愿者招募
[BZOJ1061][Noi2008]志愿者招募 试题描述 申奥成功后,布布经过不懈努力,终于成为奥组委下属公司人力资源部门的主管.布布刚上任就遇到了一个难 题:为即将启动的奥运新项目招募一批短期志愿 ...
- 网络流解线性规划问题 BZOJ1061: [Noi2008]志愿者招募
线性规划定义: 在给定有限的资源和竞争约束情况下,很多问题都可以表述为最大化或最小化某个目标.如果可以把目标指定为某些变量的线性函数,而且如果可以将资源约束指定为这些变量的等式或不等式,则得到了一个线 ...
- 从多种角度看[BZOJ 1061] [NOI 2008]志愿者招募(费用流)
从多种角度看[BZOJ 1061] [NOI 2008]志愿者招募(费用流) 题面 申奥成功后,布布经过不懈努力,终于成为奥组委下属公司人力资源部门的主管.布布刚上任就遇到了一个难题:为即将启动的奥运 ...
- 【费用流】BZOJ1061: [Noi2008]志愿者招募(这题超好)
1061: [Noi2008]志愿者招募 Time Limit: 20 Sec Memory Limit: 162 MBSubmit: 5291 Solved: 3173[Submit][Stat ...
随机推荐
- mac 上node.js环境的安装与测试
如果大家之前做过web服务器的人都知道,nginx+lua与现在流行的Node.js都是可以做web服务器的,前者在程序的写法和配置上要比后者麻烦,但用起来都是差不多.在这里建议大家如果对lua脚本语 ...
- 收藏清单: python测试框架最全资源汇总
xUnit frameworks 单元测试框架 frameworks 框架 unittest - python自带的单元测试库,开箱即用 unittest2 - 加强版的单元测试框架,适用于Pytho ...
- centos/linux下的安装Tomcat
1.启动tomcat时候需要JDK依赖 如果没有安装的请移步到该链接Centos/linux下的JDK安装 2.从官网上下载tomcat压缩包 wget -c http://apache.fayea. ...
- 史上最全的FTP网址
无帐号密码的为匿名登录 ftp://202.114.1.121 ftp://202.114.10.199 ftp://warez:cn.ftp@202.114.12.174 ftp://Music2: ...
- 各种语系的unicode对应以及local编码方式
链接:http://www.doc88.com/p-801578373970.html 一.英文 Unicode范围: 0041-005A, 0061-007A (若含数字与符号,则为0021-007 ...
- 老男孩Python全栈开发(92天全)视频教程 自学笔记20
day20课程内容: 模块: #模块一共三种:1.Python标准库 2.第三方模块 3.应用程序自定义的模块#import sysimport jisuanapp#print(jisuanapp.a ...
- ansible基本使用教程
转载请注明出处http://www.cnblogs.com/chenxianpao/p/7360349.html 一. 介绍 1. 简介 ansible是新出现的自动化运维工具,基于Pytho ...
- 洛谷P3381 - 【模板】最小费用最大流
原题链接 题意简述 模板题啦~ 题解 每次都以费用作为边权求一下最短路,然后沿着最短路增广. Code //[模板]最小费用最大流 #include <cstdio> #include & ...
- 在SpringBoot中配置aop
前言 aop作为spring的一个强大的功能经常被使用,aop的应用场景有很多,但是实际的应用还是需要根据实际的业务来进行实现.这里就以打印日志作为例子,在SpringBoot中配置aop 已经加入我 ...
- Machine Learning|Andrew Ng|Coursera 吴恩达机器学习笔记
Week1: Machine Learning: A computer program is said to learn from experience E with respect to some ...