【bzoj1221】[HNOI2001] 软件开发 费用流
题目描述
某软件公司正在规划一项n天的软件开发计划,根据开发计划第i天需要ni个软件开发人员,为了提高软件开发人员的效率,公司给软件人员提供了很多的服务,其中一项服务就是要为每个开发人员每天提供一块消毒毛巾,这种消毒毛巾使用一天后必须再做消毒处理后才能使用。消毒方式有两种,A种方式的消毒需要a天时间,B种方式的消毒需要b天(b>a),A种消毒方式的费用为每块毛巾fA, B种消毒方式的费用为每块毛巾fB,而买一块新毛巾的费用为f(新毛巾是已消毒的,当天可以使用);而且f>fA>fB。公司经理正在规划在这n天中,每天买多少块新毛巾、每天送多少块毛巾进行A种消毒和每天送多少块毛巾进行B种消毒。当然,公司经理希望费用最低。你的任务就是:为该软件公司计划每天买多少块毛巾、每天多少块毛巾进行A种消毒和多少毛巾进行B种消毒,使公司在这项n天的软件开发中,提供毛巾服务的总费用最低。
输入
第1行为n,a,b,f,fA,fB. 第2行为n1,n2,……,nn. (注:1≤f,fA,fB≤60,1≤n≤1000)
输出
最少费用
样例输入
4 1 2 3 2 1
8 2 1 6
样例输出
38
题解
费用流
本题和 网络流24题-餐巾计划问题 极为相似,唯一不同的是本题中消毒的实际相差时间为消耗时间+1
建图方法:
每个点拆成2个,分别为xi和yi。
S->xi,容量为ni,费用为0;yi->T,容量为ni,费用为0;S->yi,容量为ni(inf也一样),费用为f;
xi->xi+1,容量为inf,费用为0;xi->yi+a+1,容量为inf,费用为fa;xi->yi+b+1,容量为inf,费用为fb。
比较正经的理解方法:
将xi看作脏毛巾,将yi看作干净的毛巾。由于每天买毛巾的价格相同,所以一定是洗完或买完毛巾就立刻使用,所以yi直接向t连边。
每天能够得到ni条脏毛巾,这些脏毛巾不一定立刻送洗,所以xi想xi+1连边,表示留到下一天。
比较不正经的理解方法:
将xi看作脏毛巾,将yi看作干净的毛巾,要求每天需要ni条干净的毛巾,所以为有上下界费用流,因此原本应有边yi->xi,容量下界为ni,上界也为ni,费用为0。
其余的按照正常方法建图。
建图之后转化成一般费用流解决,发现图和上面的是一样的。
- #include <cstdio>
- #include <cstring>
- #include <queue>
- #define N 2500
- #define M 100000
- #define inf 0x7fffffff
- using namespace std;
- queue<int> q;
- int head[N] , to[M] , val[M] , cost[M] , next[M] , cnt = 1 , s , t , dis[N] , from[N] , pre[N];
- void add(int x , int y , int v , int c)
- {
- to[++cnt] = y , val[cnt] = v , cost[cnt] = c , next[cnt] = head[x] , head[x] = cnt;
- to[++cnt] = x , val[cnt] = 0 , cost[cnt] = -c , next[cnt] = head[y] , head[y] = cnt;
- }
- bool spfa()
- {
- int x , i;
- memset(from , -1 , sizeof(from));
- memset(dis , 0x3f , sizeof(dis));
- dis[s] = 0 , q.push(s);
- while(!q.empty())
- {
- x = q.front() , q.pop();
- for(i = head[x] ; i ; i = next[i])
- if(val[i] && dis[to[i]] > dis[x] + cost[i])
- dis[to[i]] = dis[x] + cost[i] , from[to[i]] = x , pre[to[i]] = i , q.push(to[i]);
- }
- return ~from[t];
- }
- int mincost()
- {
- int ans = 0 , i , k;
- while(spfa())
- {
- k = inf;
- for(i = t ; i != s ; i = from[i]) k = min(k , val[pre[i]]);
- ans += k * dis[t];
- for(i = t ; i != s ; i = from[i]) val[pre[i]] -= k , val[pre[i] ^ 1] += k;
- }
- return ans;
- }
- int main()
- {
- int n , a , b , f , fa , fb , i , x;
- scanf("%d%d%d%d%d%d" , &n , &a , &b , &f , &fa , &fb) , s = 0 , t = 2 * n + 1;
- for(i = 1 ; i <= n ; i ++ ) scanf("%d" , &x) , add(s , i , x , 0) , add(i + n , t , x , 0) , add(s , i + n , inf , f);
- for(i = 1 ; i < n ; i ++ ) add(i , i + 1 , inf , 0);
- for(i = 1 ; i <= n - a - 1 ; i ++ ) add(i , i + a + 1 + n , inf , fa);
- for(i = 1 ; i <= n - b - 1 ; i ++ ) add(i , i + b + 1 + n , inf , fb);
- printf("%d\n" , mincost());
- return 0;
- }
【bzoj1221】[HNOI2001] 软件开发 费用流的更多相关文章
- BZOJ1221 [HNOI2001]软件开发 - 费用流
题解 非常显然的费用流. 但是建图还是需要思考的QuQ 将每天分成两个节点 $x_{i,1}, x_{i,2} $, $ x_{i,1}$用于提供服务, $x_{i ,2}$ 用来从源点获得$nd[i ...
- bzoj 1221 [HNOI2001] 软件开发 费用流
[HNOI2001] 软件开发 Time Limit: 10 Sec Memory Limit: 162 MBSubmit: 1938 Solved: 1118[Submit][Status][D ...
- BZOJ 1221 [HNOI2001] 软件开发 费用流_建模
题目描述: 某软件公司正在规划一项n天的软件开发计划,根据开发计划第i天需要ni个软件开发人员,为了提高软件开发人员的效率,公司给软件人员提供了很多的服务,其中一项服务就是要为每个开发人员每天提供 ...
- bzoj1221软件开发 费用流
题目传送门 思路: 网络流拆点有的是“过程拆点”,有的是“状态拆点”,这道题应该就属于状态拆点. 每个点分需要用的,用完的. 对于需要用的,这些毛巾来自新买的和用过的毛巾进行消毒的,流向终点. 对于用 ...
- bzoj1221: [HNOI2001] 软件开发
挖坑.我的那种建图方式应该也是合理的.然后连样例都过不了.果断意识到应该为神奇建图法... #include<cstdio> #include<cstring> #includ ...
- 【BZOJ1221】【HNOI2001】软件开发 [费用流]
软件开发 Time Limit: 10 Sec Memory Limit: 162 MB[Submit][Status][Discuss] Description 某软件公司正在规划一项n天的软件开 ...
- 【费用流】bzoj1221 [HNOI2001] 软件开发
几乎为“线性规划与网络流24题”中的餐巾问题. 这里把S看成毛巾的来源,T看成软件公司,我们的目的就是让每天的毛巾满足要求(边满流). 引用题解: [问题分析] 网络优化问题,用最小费用最大流解决. ...
- BZOJ1221 [HNOI2001] 软件开发 【费用流】
题目 某软件公司正在规划一项n天的软件开发计划,根据开发计划第i天需要ni个软件开发人员,为了提高软件开发人员的效率,公司给软件人员提供了很多的服务,其中一项服务就是要为每个开发人员每天提供一块消毒毛 ...
- BZOJ 1221 软件开发(费用流)
容易看出这是显然的费用流模型. 把每天需要的餐巾数作为限制.需要将天数拆点,x’表示每天需要的餐巾,x’’表示每天用完的餐巾.所以加边 (s,x',INF,0),(x'',t,INF,0). 餐巾可以 ...
随机推荐
- iOS支付宝 9.x 版本首页效果
http://www.jianshu.com/p/7516eb852cca 支付宝 9.x 版本首页效果 对于新版支付宝首页的产品功能这里就不说什么了,一大堆人吐槽,我们只想要一个好好的支付工具,阿里 ...
- .net网站的下载地址
.net4.0网址:http://www.crsky.com/soft/6959.htmlsql server r2: http://pan.baidu.com/share/link?shareid= ...
- 第七章 动态创建HTML内容
javascript也可以改变网页的结构和内容 document.write()方法 可以方便快捷地把字符串插入到文档里 document.write("<strong>hell ...
- 干净的架构The Clean Architecture_软件架构系列
本文转载自:https://www.jdon.com/artichect/the-clean-architecture.html ,这个博客站很有历史了,博主经常翻译Github大牛的文章,值得墙裂推 ...
- C# File和Directory类
File和Directory类 作为实用类,File和Directory类都提供了许多方法,用于处理文件系统以及其中的文件和目录.这些是静态方法,涉及移动文件.查询和更新属性并创建FileStream ...
- java面试题:如果一串字符如"aaaabbc中国1512"要分别统计英文字符的数量,中文字符的数量,和数字字符的数量,假设字符中没有中文字符、英文字符、数字字符之外的其他特殊字符。
package com.swift; public class TotalNumber_String { public static void main(String[] args) { /* * 如 ...
- SummerVocation_Leaning--java动态绑定(多态)
概念: 动态绑定:在执行期间(非编译期间)判断所引用的对象的实际类型,根据实际类型调用其相应的方法.如下例程序中,根据person对象的成员变量pet所引用的不同的实际类型调用相应的方法. 具体实现好 ...
- Java 获取Web项目相对webapp地址
例如, import java.io.File; import java.io.FileInputStream; import javax.servlet.http.HttpServletReques ...
- 第五篇:selenium调用IE问题(Protected Mode settings are not the same for all zones)
代码信息: driver = webdriver.Ie()driver.get('http://www.baidu.com') 问题描述: raise exception_class(message, ...
- 多种方式实现依赖注入及使用注解定义bean
构造注入 如何给构造方法中的参数注入方法呢如下 首先bean代码如下 package cn.pojo; public class Greeting { /** * 说的话 */ private Str ...