Vijos1825 NOI2008 志愿者招募 费用流
Orz ByVoid大神的题解:https://www.byvoid.com/blog/noi-2008-employee/
学习网络流建图的好题,不难想到线性规划的模型,不过利用模型的特殊性,结合网络流的性质,可以设计出很优美的解法
#include <cstdio> #include <cstring> #include <algorithm> #include <queue> ; ; const int inf=0x7f7f7f7f; struct Edge { int to; int next; int capacity; int cost; void assign(int t,int n,int cp,int co) { to=t,next=n,capacity=cp,cost=co; } }; Edge elist[maxM*]; int head[maxN]; int ecnt; int src,sink; void initEdge() { memset(head,-,sizeof(head)); ecnt=; } inline void addEdge(int from,int to,int capacity,int cost) { elist[ecnt].assign(to,head[from],capacity,cost); head[from]=ecnt++; elist[ecnt].assign(,-cost); head[to]=ecnt++; } int N,M; int A[maxN]; int S[maxM],T[maxM],C[maxM]; void input() { scanf("%d%d",&N,&M); A[]=; A[N+]=; ;i<=N;i++) scanf("%d",A+i); ;i<=M;i++) scanf("%d%d%d",S+i,T+i,C+i); } void buildGraph() { src=; sink=N+; initEdge(); ;i<=N+;i++) { ]>) addEdge(i,sink,A[i]-A[i-],); ]<) addEdge(src,i,A[i-]-A[i],); } ;i<=N;i++) addEdge(i,i+,inf,); ;i<=M;i++) addEdge(T[i]+,S[i],inf,C[i]); } int dist[maxN]; int prevV[maxN]; int prevE[maxN]; bool inq[maxN]; std::queue<int> que; bool spfa() { memset(dist,0x7f,sizeof(dist)); dist[src]=; memset(inq,,sizeof(inq)); que.push(src); prevV[src]=prevE[src]=-; while(!que.empty()) { int cur=que.front(); que.pop(); inq[cur]=false; ;e=elist[e].next) if(elist[e].capacity) { int& to=elist[e].to; int& co=elist[e].cost; if(dist[to]>dist[cur]+co) { dist[to]=dist[cur]+co; prevV[to]=cur; prevE[to]=e; if(!inq[to]) { que.push(to); inq[to]=true; } } } } return dist[sink]<inf; } int minCostFlow() { ); while(spfa()) { int maxf=inf; ;v=prevV[v],e=prevE[v]) maxf=std::min(maxf,elist[e].capacity); ;v=prevV[v],e=prevE[v]) { res+=maxf*elist[e].cost; elist[e].capacity-=maxf; elist[e^].capacity+=maxf; } } return res; } int main() { input(); buildGraph(); printf("%d\n",minCostFlow()); ; }
Vijos1825 NOI2008 志愿者招募 费用流的更多相关文章
- BZOJ 1061: [Noi2008]志愿者招募 费用流
1061: [Noi2008]志愿者招募 题目连接: http://www.lydsy.com/JudgeOnline/problem.php?id=1061 Description 申奥成功后,布布 ...
- [BZOJ1061] [Noi2008] 志愿者招募 (费用流)
Description 申奥成功后,布布经过不懈努力,终于成为奥组委下属公司人力资源部门的主管.布布刚上任就遇到了一个难 题:为即将启动的奥运新项目招募一批短期志愿者.经过估算,这个项目需要N 天才能 ...
- 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 问怎样安排使得施工花费最少 思考:最直白的建模方式 就是每种工人可以和 ...
- 从多种角度看[BZOJ 1061] [NOI 2008]志愿者招募(费用流)
从多种角度看[BZOJ 1061] [NOI 2008]志愿者招募(费用流) 题面 申奥成功后,布布经过不懈努力,终于成为奥组委下属公司人力资源部门的主管.布布刚上任就遇到了一个难题:为即将启动的奥运 ...
- [NOI2008][bzoj1061] 志愿者招募 [费用流+巧妙的建图]
题面 传送门 思路 引入:网络流? 看到这道题,第一想法是用一个dp来完成决策 但是,显然这道题的数据并不允许我们进行dp,尤其是有10000种志愿者的情况下 那么我们就要想别的办法来解决: 贪心?这 ...
- bzoj 1061 志愿者招募 费用流
详见BYV的博客,写的非常全面https://www.byvoid.com/blog/noi-2008-employee /************************************** ...
- 【费用流】BZOJ1061: [Noi2008]志愿者招募(这题超好)
1061: [Noi2008]志愿者招募 Time Limit: 20 Sec Memory Limit: 162 MBSubmit: 5291 Solved: 3173[Submit][Stat ...
随机推荐
- bzoj1832
其实这道题是和bzoj1787一样的但我用bzoj1787MLE了,于是正好练一下树上倍增 type node=record po,next:longint; end; ..] of node; an ...
- NOI题库05 派
05:派 Description 我的生日要到了!根据习俗,我需要将一些派分给大家.我有N个不同口味.不同大小的派.有F个朋友会来参加我的派对,每个人会拿到一块派(必须一个派的一块,不能由几个派的小块 ...
- Mathlab编程-微积分在Matlab中的解法
这一章节将介绍一系列典型的微积分问题(求极限.级数.定积分.导数.重积分等)在Matlab中的求解. 首先关于极限: (1) 数列极限: 给出下面三段例程. 求解数列极限的limit函数参数说明 ...
- SRM 388(1-250pt)
题意:定义一个数为k-smooth,如果它最大的质因子不超过k.给定n和k,求不超过n的,k-smooth的数有多少个.(k <= 100, n <= 10^5) 解法:对于一个数t,判断 ...
- [2013 ACM/ICPC Asia Regional Nanjing Online C][hdu 4750]Count The Pairs(kruskal + 二分)
http://acm.hdu.edu.cn/showproblem.php?pid=4750 题意: 定义f(u,v)为u到v每条路径上的最大边的最小值..现在有一些询问..问f(u,v)>=t ...
- 基于curl 的zabbix API调用
1,认证并取得加密字段 curl -i -X POST -H 'Content-Type: application/json' -d '{"jsonrpc":"2.0&q ...
- Winform Windows Media Player 简易播放器 分类: WinForm 2014-07-31 20:12 589人阅读 评论(0) 收藏
新手上路,高手勿进! 窗体设计: 实现效果: 实现代码: using System; using System.Collections.Generic; using System.ComponentM ...
- 一个可视化的retrospective网站
IdeaBoardz - Brainstorm, Retrospect, Collaborate是一个可视化的retrospective,brainstorm的网站,比较简单易用,可以导出pdf和ex ...
- Android RecyclerView使用(一)
RecyclerView一种可以替换掉listview gridview 瀑布流等控件的新视图控件,控制视图回收和复用 ==优化内存可以替换listview 与listview的不同之处是:listv ...
- 什么是SEO?SEO干嘛的?怎么做SEO?
黑帽seo分享了这么多SEO的东西,今天在群时面遇到群亲问到了什么是SEO?SEO是干嘛的?蜗牛认为,是时候让大家知道这些不为外人所知的真相了.且听蜗牛慢慢道来吧. 一.什么是SEO?SEO是干嘛的? ...