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 志愿者招募 费用流的更多相关文章

  1. BZOJ 1061: [Noi2008]志愿者招募 费用流

    1061: [Noi2008]志愿者招募 题目连接: http://www.lydsy.com/JudgeOnline/problem.php?id=1061 Description 申奥成功后,布布 ...

  2. [BZOJ1061] [Noi2008] 志愿者招募 (费用流)

    Description 申奥成功后,布布经过不懈努力,终于成为奥组委下属公司人力资源部门的主管.布布刚上任就遇到了一个难 题:为即将启动的奥运新项目招募一批短期志愿者.经过估算,这个项目需要N 天才能 ...

  3. P3980 [NOI2008]志愿者招募 费用流 (人有多大胆地有多大产

    https://www.luogu.org/problemnew/show/P3980 感觉费用流比网络流的图更难想到,要更大胆.首先由于日期是连续的,所以图中的点是横向排列的. 这道题有点绕道走的意 ...

  4. [NOI2008]志愿者招募 (费用流)

    大意: $n$天, 第$i$天要$a_i$个志愿者. $m$种志愿者, 每种无限多, 第$i$种工作时间$[s_i,t_i]$花费$c_i$, 求最少花费. 源点$S$连第一天, 容量$INF$ 第$ ...

  5. P3980 [NOI2008]志愿者招募 (费用流)

    题意:最多1000天 每天需要至少ai个工人施工 有10000种工人可以雇佣 每种工人可以工作si到ti天 雇佣一个的花费是ci 问怎样安排使得施工花费最少 思考:最直白的建模方式 就是每种工人可以和 ...

  6. 从多种角度看[BZOJ 1061] [NOI 2008]志愿者招募(费用流)

    从多种角度看[BZOJ 1061] [NOI 2008]志愿者招募(费用流) 题面 申奥成功后,布布经过不懈努力,终于成为奥组委下属公司人力资源部门的主管.布布刚上任就遇到了一个难题:为即将启动的奥运 ...

  7. [NOI2008][bzoj1061] 志愿者招募 [费用流+巧妙的建图]

    题面 传送门 思路 引入:网络流? 看到这道题,第一想法是用一个dp来完成决策 但是,显然这道题的数据并不允许我们进行dp,尤其是有10000种志愿者的情况下 那么我们就要想别的办法来解决: 贪心?这 ...

  8. bzoj 1061 志愿者招募 费用流

    详见BYV的博客,写的非常全面https://www.byvoid.com/blog/noi-2008-employee /************************************** ...

  9. 【费用流】BZOJ1061: [Noi2008]志愿者招募(这题超好)

    1061: [Noi2008]志愿者招募 Time Limit: 20 Sec  Memory Limit: 162 MBSubmit: 5291  Solved: 3173[Submit][Stat ...

随机推荐

  1. bzoj3689

    这题做法很多可以通过类似noi超级钢琴那道题目的做法用可持久化+trie来做还可以直接在trie树上维护size域然后类似查找k大的做法做总之还是比较水的 type node=record kth,n ...

  2. 用delphi的THTTPRIO控件调用了c#写的webservice。

    用delphi的THTTPRIO控件调用了c#写的webservice. 下面是我调试时遇到的一些问题: 1,导入wsdl文件:file--new----other----wenservice---W ...

  3. unity3d Human skin real time rendering plus 真实模拟人皮实时渲染 plus篇

    最近逃课做游戏,逃的有几门都要停考了,呵呵呵,百忙之中不忘超炒冷饭,感觉之前的人皮效果还是不够好,又改进了一些东西 首先上图 放大看细节 显而易见的比上次的效果要好很多,此次我把模型用3dmax进行了 ...

  4. 【转】OpenGL基础图形编程(一)

    原文:http://blog.chinaunix.net/uid-20638550-id-1909183.html  分类: 一.OpenGL与3D图形世界 1.1.OpenGL使人们进入三维图形世界 ...

  5. Bzoj 2038: [2009国家集训队]小Z的袜子(hose) 莫队,分块,暴力

    2038: [2009国家集训队]小Z的袜子(hose) Time Limit: 20 Sec  Memory Limit: 259 MBSubmit: 5763  Solved: 2660[Subm ...

  6. typedef用法小结

    typedef用法小结- - 注意:本文转自网络,版权归原作者所有. typedef typedef用法小结- - 这两天在看程序的时候,发现很多地方都用到typedef,在结构体定义,还有一些数组等 ...

  7. [Hibernate] 注解映射例子

    Hibernate 注解(Hibernate Annotation) 是一种比较新的方式,通过在 java 简单类增加注解,来声明 java 类和数据库表的映射,作用和 xml 文件相似.hibern ...

  8. Java GC 专家系列5:Java应用性能优化的原则

    本文是GC专家系列中的第五篇.在第一篇理解Java垃圾回收中我们学习了几种不同的GC算法的处理过程,GC的工作方式,新生代与老年代的区别.所以,你应该已经了解了JDK 7中的5种GC类型,以及每种GC ...

  9. iOS开发之获取WIFI信号强度

    虽然各种直接获取信号强度的api都被封杀了.但是还有一个另类的黑魔法可以获取到.那就是遍历UIStatusBar了 - (void)getSignalStrength{ UIApplication * ...

  10. 用bootstrap结合php搭建MIS系统框架【转载】

    bootstrap目前比较火,抽空简单了解一下 官方介绍:Bootstrap, from Twitter基于HTML,CSS,JAVASCRIPT的简洁灵活的流行前端框架及交互组件集 http://t ...