日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 人文社科 > 生活经验 >内容正文

生活经验

洛谷P4480 【[BJWC2018]餐巾计划问题】

發布時間:2023/11/27 生活经验 40 豆豆
生活随笔 收集整理的這篇文章主要介紹了 洛谷P4480 【[BJWC2018]餐巾计划问题】 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

這道題和網絡流 \(24\) 題中的餐巾計劃的確不一樣, \([\) \(BJWC\) \(2018\) \(]\) 餐巾計劃問題的數據范圍更大。

一個餐廳在相繼的 \(n\) 天里,每天需用的餐巾數不盡相同。假設第 \(i\)\((\) \(i\) \(=\) \(1\) \(,\) \(2\) \(,\) \(...\) \(,\) \(n\) \()\)需要 \(ri\) 塊餐巾。餐廳可以在任意時刻購買新的餐巾,每塊餐巾的費用為 \(p\)

使用過的舊餐巾,則需要經過清洗才能重新使用。把一塊舊餐巾送到清洗店 \(A\) ,需要等待 \(m1\) 天后才能拿到新餐巾,其費用為 \(c1\);把一塊舊餐巾送到清洗店 \(B\) ,需要等待 \(m2\) 天后才能拿到新餐巾,其費用為 \(c2\)

例如,將一塊第k天使用過的餐巾送到清洗店 \(A\) 清洗,則可以在第 \(k\) \(+\) \(m1\) 天使用。

對于 \(50\) \(%\) 的數據,我們有一個很經典的網絡流做法:餐巾計劃問題。

但是數據規模擴大后就顯然不能用網絡流求解了。

分兩種情況:

\(1\) .快洗店更貴:

考慮到先買和后買餐巾所對答案和過程不會造成影響,且當買餐巾 \(c\) 條達到最優解時,顯然 \(c\) \(+\) \(k\) 的花費比 \(c\) \(+\) \(k\) \(+\) \(1\) 的花費更少。

并且不難感性證出 \(c\) \(-\) \(k\) 的花費比 \(c\) \(-\) \(k\) \(-\) \(1\) 的花費更少 ( 會在最優情況下多次使用快洗店的餐巾使得錢變多 ) 。

因此我們可以三分求解。

最便宜的顯然是先使用新的毛巾,等到沒了的時候使用慢洗店的,最差使用快洗店的得出答案,使用隊列維護一下即可 \((\) 雖然這么說,也是挺惡心的,我對著別人的代碼調了 \(3h\) 才過,可能現在讓我解釋代碼都解釋不明白。 \()\)

\(2\) .快洗點更便宜:

那就都快洗,這是顯然的。

這是可愛的代碼

#include<cmath>
#include<cstdio>
#include<cstring>
#include<iostream>
#include<algorithm>
using namespace std;
const int N=200010;
const int INF=2147483647;
inline int read(){int X=0,w=1;char ch=0;while(ch<'0'||ch>'9'){if(ch=='-')w=-1;ch=getchar();}while(ch>='0'&&ch<='9')X=(X<<1)+(X<<3)+ch-'0',ch=getchar();return X*w;
}
int t[N],num[N],q[N],cnt,d,n1,n2,c1,c2,tc;
int sn,sm,so,en,em,eo;
inline void add(int x,int p){q[en]=x;num[en++]=p;
}
int f(int k){sn=sm=so=en=em=eo=0;int ans=(tc-c2)*k;add(-2000000,k);for(int i=1;i<=d;i++){int j=t[i];while(sn!=en&&i-q[sn]>=n1){num[em]=num[sn];q[em++]=q[sn++];}while(sm!=em&&i-q[sm]>=n2){num[eo]=num[sm];q[eo++]=q[sm++];}while(j>0){if(so!=eo){if(num[eo-1]>j){ans+=c2*j;num[eo-1]-=j;break;}else{ans+=c2*num[eo-1];j-=num[eo-1];eo--;}}else if(sm!=em){if(num[em-1]>j){ans+=c1*j;num[em-1]-=j;break;}else{ans+=c1*num[em-1];j-=num[em-1];em--;}}else return INF;}add(i,t[i]);}return ans;
}
int sfen(int l,int r){while(233){if(r-l<=2){int m=INF;for(int i=l;i<r;i++)m=min(m,f(i));return m;}int mid1=l+(r-l)/3,mid2=l+2*(r-l)/3;int a=f(mid1);if(a!=INF&&a<=f(mid2))r=mid2;else l=mid1;}
}
int main(){d=read(),n1=read(),n2=read(),c1=read(),c2=read(),tc=read();if(n1>n2){swap(n1,n2);swap(c1,c2);}if(c1<=c2)n2=2000001,c2=101;int tsum=0;for(int i=1;i<=d;i++){t[i]=read();tsum+=t[i];}printf("%d\n",sfen(0,tsum+1));return 0;
}

轉載于:https://www.cnblogs.com/errichto/p/11317278.html

總結

以上是生活随笔為你收集整理的洛谷P4480 【[BJWC2018]餐巾计划问题】的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。

主站蜘蛛池模板: 国产在线播放网站 | 日韩视频网址 | 日本人毛片 | 欧美一区二区三区免 | 欧美精品色 | 老妇高潮潮喷到猛进猛出 | 风间由美一区 | 中国在线观看免费视频 | 成人在线观看网站 | 插女生下面 | 黄色大片儿. | 久久久91精品国产一区二区三区 | 欧美1| 亚洲国产精品久久 | 亚洲欧洲国产视频 | 一级aaa毛片| 丰满秘书被猛烈进入高清播放在 | 日日日操| 国产精品成人久久久久 | 黄色三级网站在线观看 | 精品久久久免费 | 青青福利视频 | 午夜精品一区二区三区在线播放 | 99re在线观看| 操www| 三级av片 | 麻豆精品一区 | 免费在线国产 | 国产伦精品一区二区三区妓女 | 欧美xxxx在线 | 欧美一级鲁丝片 | 开心激情网站 | 免费一级特黄特色大片 | 亚洲精品无码久久久久 | 人人草人人看 | 夜夜草天天草 | kendra lust free xxx| 欧美特级黄色录像 | 豆豆色成人网 | 男生操女生屁股 | 久久精品视频网 | 激情 亚洲 | 日韩国产欧美视频 | 亚洲区小说区图片区 | 成人在线观看你懂的 | 成人学院中文字幕 | 蜜桃导航-精品导航 | 成人网在线免费观看 | 琪琪电影午夜理论片八戒八戒 | 3d欧美精品动漫xxxx无尽 | 伊人操 | 奇米网888 | 又欲又污又肉又黄短文 | 图书馆的女友动漫在线观看 | 亚洲AV乱码国产精品观看麻豆 | 性猛交富婆╳xxx乱大交天津 | 久久久久久成人精品 | 双性人bbww欧美双性 | 午夜aaa片一区二区专区 | 成人免费在线看片 | 亚洲涩涩图 | 精品91自产拍在线观看二区 | 精品视频www| 天堂免费在线视频 | 美女大黄网站 | 日韩成人午夜电影 | 亚洲天堂网在线观看视频 | 日韩亚洲一区二区 | 亚洲乱码国产乱码精品精剪 | 久久久一二三四 | 精品一区二区在线免费观看 | 噜噜啪啪 | 骚虎tv| 在线免费av网 | 日韩私人影院 | 草久免费视频 | 丝袜性爱视频 | 亚洲国产精品视频在线观看 | 日韩在线观看一区 | 女性毛片 | 国产黄视频网站 | av片国产| 日本亚洲最大的色成网站www | 午夜男人网 | 在线播放不卡 | 国产极品视频 | 国产成人在线视频观看 | 亚洲免费精品视频在线观看 | 黄色免费网站 | 亚洲AV成人无码久久精品巨臀 | 日韩精品黄 | 美女啪啪无遮挡 | 91国内视频| 欧美性猛交aaaa片黑人 | 高清不卡毛片 | 毛片最新网址 | 人妻熟女一区二区aⅴ水 | 色乱码一区二区三区在线男奴 | 国产18照片色桃 |