【HAOI2010】订货
可以DP也可以是费用流,然而被我用非常简单的DP破了【开心】
原题:
某公司估计市场在第i个月对某产品的需求量为Ui,已知在第i月该产品的订货单价为di,上个月月底未销完的单位产品要付存贮费用m,假定第一月月初的库存量为零,第n月月底的库存量也为零,问如何安排这n个月订购计划,才能使成本最低?每月月初订购,订购后产品立即到货,进库并供应市场,于当月被售掉则不必付存贮费。假设仓库容量为S。
0<=n<=50,0<=m<=10,0<=S<=10000,0<=Ui<=10000,0<=di<=100
恩紫萱的讲解说要用队列优化DP,我太弱没看懂,自己想出了一个我觉得比较妙的方法DP掉了
核心思路是在买东西的时候f[i]只与f[i-1]的最优值有关(注意是最优值)
然后要买的时候从1到S顺推,f[i]=min(f[i],f[i-1]+d[i])
恩原理我语文不好,直接丢个图吧

可以理解为f[i-1]代表了1到i-1所有的方案,但是都没有f[i]优,再往上考虑的话,由于增加的费用都是一样的,所以和f[1]到f[i-1]有关的方案不会优于f[i]相关的方案,就只考虑f[i]了
如果f[i]不是更优,f[i-1]代表了f[1]到f[i-1]的方案,只管使用即可
然后还有许多需要注意的细节(我就是因为细节问题拖了很久才A quq)
首先货物是可以进货不入库直接卖,不占用仓库空间,所以实际上仓库有M+a[i]的储存空间(每个月的需求也可能超过仓库容量),然后每个月结束的时候f中1到M不用处理,下个月直接转移即可,但是M+1到M+a[i]这一段一定要处理成正无穷,不然会影响到下个月(我就是因为这个细节卡了一下午,差点弃疗quq)
还有更多的细节问题,大家自己体验吧一。一
DP代码非常短
代码(DP):
#include<iostream>
#include<cstdio>
#include<algorithm>
#include<cstring>
#include<cmath>
using namespace std;
int read(){int z=,mark=; char ch=getchar();
while(ch<''||ch>''){if(ch=='-')mark=-; ch=getchar();}
while(ch>=''&&ch<=''){z=(z<<)+(z<<)+ch-''; ch=getchar();}
return z*mark;
}
const int oo=;
int n,m,ns; int a[],b[];
int f[];
int main(){//freopen("ddd.in","r",stdin);
memset(f,,sizeof(f));
cin>>n>>ns>>m;
for(int i=;i<=n;i++) a[i]=read();
for(int i=;i<=n;i++) b[i]=read();
f[]=; a[]=;
for(int i=;i<=n;i++){
for(int j=;j<=m;j++) f[j]=f[j+a[i-]]+j*ns;
for(int j=m+;j<=m+a[i-];j++) f[j]=oo;
for(int j=;j<=m+a[i];j++) f[j]=min(f[j],f[j-]+b[i]);
}
cout<<f[a[n]]<<endl;
return ;
}
======================================================下面是费用流======================================================
至于费用流呐,建图也非常好想
首先利用割的思想,每个月到汇一条流量为需求,费用0的边,割掉这条边表示这个月的费用满足了
然后源到每个月一条流量正无穷,费用为这个月进货费用的边,表示物品可以随意买
每个月到下个月一条流量为仓库容量,费用为储存话费的边,表示上个月的货可以继承到下个月
至于我是怎么想出来的……直觉……我觉得还要继续发掘一下这其中潜在的思路规律
代码也很简单,标准的费用流模板:
#include<iostream>
#include<cstdio>
#include<algorithm>
#include<cstring>
#include<cmath>
using namespace std;
int read(){int z=,mark=; char ch=getchar();
while(ch<''||ch>''){if(ch=='-')mark=-; ch=getchar();}
while(ch>=''&&ch<=''){z=(z<<)+(z<<)+ch-''; ch=getchar();}
return z*mark;
}
const int oo=;
struct ddd{int next,y,evalue,rev,cost;}e[]; int LINK[],ltop=;
inline void insert(int x,int y,int z,int _cost){
e[++ltop].next=LINK[x];LINK[x]=ltop;e[ltop].y=y;e[ltop].evalue=z;e[ltop].rev=ltop+;e[ltop].cost=_cost;
e[++ltop].next=LINK[y];LINK[y]=ltop;e[ltop].y=x;e[ltop].evalue=;e[ltop].rev=ltop-;e[ltop].cost=-_cost;
}
int n,m,ns; int s,t;
int dist[];
int QUEUE[],head=; bool visited[];
int last[],last_e[];
bool spfa(){
memset(visited,,sizeof(visited));
memset(dist,,sizeof(dist));
QUEUE[head=]=s; dist[s]=;
for(int k=;k<=head;k++){
for(int i=LINK[QUEUE[k]];i;i=e[i].next)
if(e[i].evalue && dist[QUEUE[k]]+e[i].cost<dist[e[i].y]){
dist[e[i].y]=dist[QUEUE[k]]+e[i].cost;
last[e[i].y]=QUEUE[k],last_e[e[i].y]=i;
if(!visited[e[i].y]) QUEUE[++head]=e[i].y,visited[e[i].y]=true;
}
visited[QUEUE[k]]=false;
}
return dist[t]<oo;
}
int cost_flow(){
int bowl=;
while(spfa()){
int min_flow=oo;
for(int i=t;i!=s;i=last[i]) min_flow=min(min_flow,e[last_e[i]].evalue);
for(int i=t;i!=s;i=last[i]){
bowl+=min_flow*e[last_e[i]].cost;
e[last_e[i]].evalue-=min_flow,e[e[last_e[i]].rev].evalue+=min_flow;
}
}
return bowl;
}
int main(){//freopen("ddd.in","r",stdin);
cin>>n>>ns>>m; s=,t=n+;
for(int i=;i<=n;i++) insert(i,t,read(),);
for(int i=;i<=n;i++) insert(s,i,oo,read());
for(int i=;i<n;i++) insert(i,i+,m,ns);
cout<<cost_flow()<<endl;
return ;
}
【HAOI2010】订货的更多相关文章
- BZOJ 2424: [HAOI2010]订货
2424: [HAOI2010]订货 Time Limit: 10 Sec Memory Limit: 128 MBSubmit: 915 Solved: 639[Submit][Status][ ...
- 2424: [HAOI2010]订货
2424: [HAOI2010]订货 Time Limit: 10 Sec Memory Limit: 128 MBSubmit: 922 Solved: 642[Submit][Status][ ...
- BZOJ 2424: [HAOI2010]订货 费用流
2424: [HAOI2010]订货 Description 某公司估计市场在第i个月对某产品的需求量为Ui,已知在第i月该产品的订货单价为di,上个月月底未销完的单位产品要付存贮费用m,假定第一月月 ...
- BZOJ 2424: [HAOI2010]订货(最小费用最大流)
最小费用最大流..乱搞即可 ------------------------------------------------------------------------------ #includ ...
- 【BZOJ2424】[HAOI2010]订货(费用流)
[BZOJ2424][HAOI2010]订货(费用流) 题面 BZOJ 洛谷 题解 傻逼费用流吧... 一开始理解错意思了,仓库大小为\(m\)的含义是留到下个月最多为\(m\),而不是任意时刻的容量 ...
- 【BZOJ2424】[HAOI2010]订货 最小费用流
[BZOJ2424][HAOI2010]订货 Description 某公司估计市场在第i个月对某产品的需求量为Ui,已知在第i月该产品的订货单价为di,上个月月底未销完的单位产品要付存贮费用m,假定 ...
- bzoj2424 [HAOI2010]订货 dp+单调性
[HAOI2010]订货 Time Limit: 10 Sec Memory Limit: 128 MBSubmit: 1311 Solved: 884[Submit][Status][Discu ...
- BZOJ_2424_[HAOI2010]订货_最小费用最大流
BZOJ_2424_[HAOI2010]订货_最小费用最大流 Description 某公司估计市场在第i个月对某产品的需求量为Ui,已知在第i月该产品的订货单价为di,上个月月底未销完的单位产品要付 ...
- P2517 [HAOI2010]订货(dp)
P2517 [HAOI2010]订货 设$f[i][j]$表示第$i$个月,库存为$j$的最小代价 枚举上个月的库存$k$,那么$f[i][j]=f[i-1][k]+(j+U[i]-k)*D[i]+j ...
- bzoj2424 [HAOI2010]订货
模拟一下仓库里面存储物品的价格情况即可,如果当前物品大于仓库里面物品那么就替换一下仓库里的物品,然后订货直接从仓库里先取,仓库里不够则直接购买,每次做完后记得买当前物品填补一下仓库直至仓库填满,当然这 ...
随机推荐
- 雷林鹏分享:Ruby 安装 - Windows
Ruby 安装 - Windows 下面列出了在 Windows 机器上安装 Ruby 的步骤. 注意:在安装时,您可能有不同的可用版本. 下载最新版的 Ruby 压缩文件.请点击这里下载. 下载 R ...
- [Java代码] Java是自学好还是参加培训班好?
ava 是由Sun Microsystems公司于1995年5月推出的高级程序设计语言. Java可运行于多个平台,如Windows, Mac OS,及其他多种UNIX版本的系统. 本教程给大家简单介 ...
- linux系统方面的知识
1.什么是Linux? 组成部分:硬件.内核.lib库.应用程序 硬件:工作中真正工作的组成部分是硬件 linux内核(kernel):管理硬件 Linux团队管理的版本 lib库:封 ...
- 12月15日 session:Ruby on Rails Security Guide//从第3节开始没有学习//关于find_by 和where的区别用法思考。
http://guides.rubyonrails.org/security.html#user-management 2.session笔记见13日的随笔. http://www.cnblogs.c ...
- 『cs231n』作业2选讲_通过代码理解优化器
1).Adagrad一种自适应学习率算法,实现代码如下: cache += dx**2 x += - learning_rate * dx / (np.sqrt(cache) + eps) 这种方法的 ...
- hdu2328 kmp
Beside other services, ACM helps companies to clearly state their “corporate identity”, which includ ...
- ASP.NET的路由系统
一.URL与物理文件的分离 1.URL与物理文件的分离 对于一个 ASP.NET Web Form应用来说,任何一个请求都对应着某个具体的物理文件.部署在Web服务器上的物理文件可以是静态的(比如图片 ...
- 如何用xmlspy将xml文档生成xsd文件
所以我们有必要知道如何通过xmlspy这个非常方便的工具进行xml的转换工作.点击“File”-“New”系统会弹出“create new document”的窗口,此时选择“xml XML docu ...
- HashTable vs HashMap(三)
HashTable的应用非常广泛,HashMap是新框架中用来代替HashTable的类,也就是说建议使用HashMap,不要使用HashTable. 可能你觉得HashTable很好用,为什么不用呢 ...
- (zz)设置单元格的宽度和高度
(zz)设置单元格的宽度和高度 博客分类: POI生成Excel 在Excel中,单元格的宽度其实就是列的宽度,因为Excel假设这一列的单元格的宽度肯定一致.所以要设置单元格的宽度,我们就得从列 ...