bzoj 1221 [HNOI2001] 软件开发 费用流

[HNOI2001] 软件开发

Time Limit: 10 Sec  Memory Limit: 162 MB
Submit: 1938  Solved: 1118
[Submit][Status][Discuss]

Description

某软件公司正在规划一项n天的软件开发计划,根据开发计划第i天需要ni个软件开发人员,为了提高软件开发人员的效率,公司给软件人员提供了很多的服务,其中一项服务就是要为每个开发人员每天提供一块消毒毛巾,这种消毒毛巾使用一天后必须再做消毒处理后才能使用。消毒方式有两种,A种方式的消毒需要a天时间,B种方式的消毒需要b天(b>a),A种消毒方式的费用为每块毛巾fA, B种消毒方式的费用为每块毛巾fB,而买一块新毛巾的费用为f(新毛巾是已消毒的,当天可以使用);而且f>fA>fB。公司经理正在规划在这n天中,每天买多少块新毛巾、每天送多少块毛巾进行A种消毒和每天送多少块毛巾进行B种消毒。当然,公司经理希望费用最低。你的任务就是:为该软件公司计划每天买多少块毛巾、每天多少块毛巾进行A种消毒和多少毛巾进行B种消毒,使公司在这项n天的软件开发中,提供毛巾服务的总费用最低。

Input

第1行为n,a,b,f,fA,fB. 第2行为n1,n2,……,nn. (注:1≤f,fA,fB≤60,1≤n≤1000)

Output

最少费用

Sample Input

4 1 2 3 2 1
8 2 1 6

Sample Output

38

HINT

 

题解:这个和网络流24题里的餐巾纸那道题一样的,有一个

   显然的贪心,没必要多买,然后

 
  1 #include<cstring>
  2 #include<cstdio>
  3 #include<algorithm>
  4 #include<iostream>
  5 #include<cmath>
  6 #include<queue>
  7 
  8 #define N 1007
  9 #define inf 1000000007
 10 using namespace std;
 11 inline int read()
 12 {
 13     int x=0,f=1;char ch=getchar();
 14     while(!isdigit(ch)){if(ch=='-')f=-1;ch=getchar();}
 15     while(isdigit(ch)){x=(x<<1)+(x<<3)+ch-'0';ch=getchar();}
 16     return x*f;
 17 }
 18 
 19 int n,a,b,f,fa,fb,S,T;
 20 bool boo[N<<2];
 21 int dis[N<<2];
 22 int cnt=1,hed[N<<2],nxt[N<<4],rea[N<<4],val[N<<4],fee[N<<4];
 23 struct Node
 24 {
 25     int e,fa;
 26     void init()
 27     {
 28         e=fa=-1;
 29     }
 30 }e[N<<2];
 31 
 32 void add(int u,int v,int z,int w)
 33 {
 34     nxt[++cnt]=hed[u];
 35     hed[u]=cnt;
 36     rea[cnt]=v;
 37     val[cnt]=z;
 38     fee[cnt]=w;
 39 }
 40 void add_two_way(int u,int v,int z,int w)
 41 {
 42     add(u,v,z,w);
 43     add(v,u,0,-w);
 44 }
 45 bool Spfa()
 46 {
 47     for (int i=S;i<=T;i++)
 48         dis[i]=inf,e[i].init(),boo[i]=false;
 49     queue<int>q;
 50     q.push(S);boo[S]=true,dis[S]=0;
 51     while(!q.empty())
 52     {
 53         int u=q.front();q.pop();
 54         for (int i=hed[u];i!=-1;i=nxt[i])
 55         {
 56             int v=rea[i],cost=fee[i];
 57             if (dis[v]>dis[u]+cost&&val[i]>0)
 58             {
 59                 dis[v]=dis[u]+cost;
 60                 e[v].fa=u,e[v].e=i;
 61                 if (!boo[v])
 62                 {
 63                     boo[v]=true;
 64                     q.push(v);
 65                 }
 66             }
 67         }
 68         boo[u]=false;
 69     }
 70     if (dis[T]!=inf) return true;
 71     else return false;
 72 }
 73 int mfmc()
 74 {
 75     int ans=0;
 76     while(Spfa())
 77     {
 78         int x=inf;
 79         for (int i=T;e[i].fa!=-1;i=e[i].fa)
 80             x=min(x,val[e[i].e]);
 81         ans+=dis[T]*x;
 82         for (int i=T;e[i].fa!=-1;i=e[i].fa)
 83             val[e[i].e]-=x,val[e[i].e^1]+=x;
 84     }
 85     return ans;
 86 }
 87 int main()
 88 {
 89     memset(hed,-1,sizeof(hed));
 90     n=read(),a=read(),b=read(),f=read(),fa=read(),fb=read();
 91     S=0,T=n*2+1;
 92     for (int i=1;i<=n;i++)
 93     {
 94         if (i+a+1<=n) add_two_way(i,i+n+a+1,inf,fa);
 95         if (i+b+1<=n) add_two_way(i,i+n+b+1,inf,fb);
 96         if (i+1<=n) add_two_way(i,i+1,inf,0);
 97     }
 98     for (int i=1;i<=n;i++)
 99     {
100         int x=read();
101         add_two_way(S,i,x,0);
102         add_two_way(S,i+n,x,f);
103         add_two_way(i+n,T,x,0);
104     }
105     printf("%d\n",mfmc());
106 }

 

posted @ 2018-04-14 20:30  Kaiser-  阅读(149)  评论(0编辑  收藏  举报