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

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

O(V*n)的多重背包问题

發布時間:2025/3/15 编程问答 39 豆豆
生活随笔 收集整理的這篇文章主要介紹了 O(V*n)的多重背包问题 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

多重背包問題:

  有n件物品,第i件價值為wi,質量為vi,有c1件,問,給定容量V,求獲得的最大價值。

  

樸素做法:

  視為0,1,2,...,k種物品的分組背包 [每組只能選一個]

  f[i][j]=Max(f[i][j-k*v[i]]+k*w[i])

  但是i,j,k都要枚舉,復雜度為 n*V*k

?

樸素做法的改進:

  因為發現用二進制可以表示1..k之內的所有數 [整數二進制打開后為01串,所以可以被二進制表示]

  所以將k個物品拆分成1,2,4...2^m,k-2^m ? ( 其中2^m<=k<2^(m+1) ) 這些物品,然后變成01背包問題。

  但是n的數目增多了,復雜度為 n*V*logk

?

利用單調隊列的改進:

  1.我們可以發現每個容量都能表示成 v*x+d 的形式[ v表示當前考慮的物品的容量 ]

  2.在上一點的啟發下,我們發現一個f[v*x+d]在考慮當前物品時,只能由f[v*y+d]轉移而來。 [其中x-y<=k]。

  也就是說,對v取模的余數相同的容量之間才能互相轉移,而且要求x-y<=k。又因為求的是最大值的轉移,所以滿足單調隊列的適用性。

  于是乎,我們對于余數d相同的容量分別建一個單調隊列,然后枚舉x f[x*v+d],進行轉移即可。

  

1 #include<cstdio> 2 #include<cstring> 3 4 inline int in(){ 5 int x=0,flag=1;char ch=getchar(); 6 while(ch!='-' && (ch>'9' || ch<'0')) ch=getchar(); 7 if(ch=='-') flag=-1,ch=getchar(); 8 while(ch>='0' && ch<='9') x=x*10+ch-'0',ch=getchar(); 9 return x*flag; 10 } 11 12 int a[200005],b[200005],f[200005]; 13 int w,v,k,n,V,l,r; 14 15 void insert(int x,int y){ 16 while(l<=r && b[r]<=y) r--; 17 a[++r]=x; b[r]=y; 18 } 19 20 inline int Max(int a,int b){ 21 if(a>b) return a;return b; 22 } 23 24 int main(){ 25 n=in(),V=in(); 26 int Lim; 27 for(int i=1;i<=n;i++){ 28 v=in();w=in();k=in(); 29 if(k==1){ 30 for(int j=V;j>=v;j--) 31 f[j]=Max(f[j],f[j-v]+w); 32 continue; 33 } 34 else if(k<0){ 35 for(int j=v;j<=V;j++) 36 f[j]=Max(f[j],f[j-v]+w); 37 continue; 38 } 39 if(V/v<k) k=V/v; 40 for(int d=0;d<v;d++){ 41 l=1,r=0;Lim=(V-d)/v; 42 for(int x=0;x<=Lim;x++){ 43 insert(x,f[x*v+d]-x*w); 44 if(a[l]<x-k) l++; 45 f[x*v+d]=b[l]+x*w; 46 } 47 } 48 } 49 printf("%d",f[V]); 50 return 0; 51 } View Code

codevs 3269 混合背包

AC通道:http://codevs.cn/problem/3269/

轉載于:https://www.cnblogs.com/Robert-Yuan/p/4852423.html

總結

以上是生活随笔為你收集整理的O(V*n)的多重背包问题的全部內容,希望文章能夠幫你解決所遇到的問題。

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

主站蜘蛛池模板: 在线观看久草 | 男女扒开双腿猛进入爽爽免费 | 国产又粗又猛又爽又黄无遮挡 | 三级黄色片网站 | 看成人片 | 欧美乱大交 | 人与动物2免费观看完整版电影高清 | 久久久亚洲一区 | 特级一级黄色片 | 我的邻居在线观看 | 色哟哟视频在线观看 | 亚洲一区二区自拍 | 人妻巨大乳hd免费看 | 中文字幕h | 91伊人久久 | 在线亚洲天堂 | 日韩中文字幕av在线 | 伊人影视大全 | 在线视频亚洲 | 激情超碰 | 国产精品国色综合久久 | 亚洲精品国产手机 | 午夜伦理在线观看 | 亚洲第一成年人网站 | 国产极品探花 | 午夜精品久久久久久久久久蜜桃 | 久久久久久久91 | 国产99对白在线播放 | 尤物av在线| 波多野结衣导航 | 激情欧美日韩 | 久久久久久www | 国产一级做a爱片久久毛片a | 日日色综合| 91丨porny丨国产 | 一级黄色免费视频 | 午夜免费成人 | 国产一区欧美一区 | 日日草日日干 | 在线免费成人网 | 香蕉久久国产av一区二区 | 清纯粉嫩极品夜夜嗨av | 老熟妇毛茸茸 | 123成人网| r级无码视频在线观看 | 激情久久久久 | 色婷五月 | 激情综合网五月激情 | 午夜aa| 香蕉成人在线视频 | 成人午夜激情视频 | 精品国产乱码久久久久 | 久久高清毛片 | 亚洲福利一区二区 | 粉嫩aⅴ一区二区三区四区五区 | 国产一区二区三区欧美 | 韩国三级在线视频 | 国产精品久久网 | 长河落日电视连续剧免费观看01 | 国产aⅴ精品一区二区三区久久 | 国产成人h | 久久国产亚洲精品无码 | 免看一级a毛片一片成人不卡 | 日本一区二区三区在线观看视频 | 日日操狠狠操 | 韩国bj大尺度vip福利网站 | 久久1234 | 自拍偷拍亚洲精品 | 亚洲天堂av女优 | 日本一级一片免费视频 | 国产视频播放 | 一区二区黄色片 | 久久综合一区二区三区 | 成人区一区二区 | 亚洲熟妇无码另类久久久 | 成 人免费va视频 | 超碰青草 | 欧美激情一区二区视频 | 免费在线播放毛片 | 国产黄网在线观看 | 少妇一级淫片免费放 | 日韩欧美在线一区 | www.欧美在线观看 | 岛国av在线免费观看 | 性一交一乱一区二区洋洋av | 成人刺激视频 | 麻豆国产尤物av尤物在线观看 | 桃色视频网 | 欧美性生活免费视频 | av自拍网 | 色婷婷综合久久久久中文字幕 | 在线观看免费视频一区 | 四虎影院永久地址 | 小日子的在线观看免费第8集 | 91蝌蚪91九色白浆 | 91在线视频观看 | 折磨小男生性器羞耻的故事 | 人妻少妇偷人精品久久久任期 | 乳女教师の诱惑julia |