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 ...
随机推荐
- Delphi ADOQuery的速度优化 转
今天终于把纠缠了几天的问题改完了,说到底只是一个很小的问题,就是ADOQuery的一个小属性. 把控件DBGridEh的一列的checkbox设为true,将其绑定DataSourceA和DOQu ...
- XenServer的某台机器一直pending住怎么办
XenServer某台VM在操作后,图标一直显示成黄色,无法完成操作,成假死的状态.可以用下面命令强制终止VM: 1.在你假死的机器获得UUID 2.在XenServer的控制台输入如下命令获得ID ...
- 【算法入门】广度/宽度优先搜索(BFS)
广度/宽度优先搜索(BFS) [算法入门] 1.前言 广度优先搜索(也称宽度优先搜索,缩写BFS,以下采用广度来描述)是连通图的一种遍历策略.因为它的思想是从一个顶点V0开始,辐射状地优先遍历其周围较 ...
- django运行django-admin.py无法创建网站
安装django的步骤: 1.安装python,选择默认安装在c盘即可.设置环境变量path,值添加python的安装路径. 2.下载ez_setup.py,下载地址:http://peak.tele ...
- mac svn命令
转载:Mac下svn command命令 svn help command 获取子命令说明 svn info $URL 查看工作空间信息 svn list 显示当前目录下svn记录文件列表,不访 ...
- 公司框架将入参Map化
1.Map<String,Object> map = BeanUtil.describe(inDto);
- Parallel.Foreach的并发问题解决方法-比如爬虫WebClient
场景五:线程局部变量 Parallel.ForEach 提供了一个线程局部变量的重载,定义如下: public static ParallelLoopResult ForEach<TSource ...
- 给iphone模拟器添加照片
http://blog.csdn.net/StudyRecord/archive/2011/04/06/6305271.aspx 由于模拟器上没有照相机,要向Photos应用程序添加照片,必须按照以下 ...
- 单元测试时候使用[ClassInitialize]会该方法必须是静态的公共方法,不返回值并且应采用一个TestContext类型的参数报错的解决办法
using Microsoft.VisualStudio.TestTools.UnitTesting; 如果该DLL应用的是 C:\Program Files\Microsoft Visual Stu ...
- winform渐变窗口显示/关闭
//渐渐的消失 for (int iNum = 10; iNum >= 0; iNum --) { //变更窗体的不透明度 this.Opacity = 0.1 * iNum; //暂停 Sys ...