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

歡迎訪問 生活随笔!

生活随笔

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

编程问答

[BZOJ4182]Shopping

發布時間:2023/12/9 编程问答 31 豆豆
生活随笔 收集整理的這篇文章主要介紹了 [BZOJ4182]Shopping 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

description

權限題。
樹上\(n\)個節點每個節點都有一種物品,每種物品有其價值,價格,數量,只能買一個連通塊中的物品,求\(m\)元能買到物品價值的最大值。

data range

\[ n\le 500,m\le 4000,T\le 5,c_i\le m\]

solution

緊跟\(YCB\)聚聚的步伐

首先可以想到以每個點為根做樹形依賴背包

樹形依賴背包

\(f[i][j]\)表示在子樹\(i\)中買了價值為\(j\)的物品

如果直接對父親轉移是每次\(O(nc^2)\)

我們把每個連通塊考慮成一條路徑,如果選某個點就前往這個點\(dfn\)序的下一個點,
如果不選就跳過整棵子樹做轉移

這樣做再加上多重背包的單調隊列優化可以達到每次\(O(nc)\)

總復雜度為\(O(n^2c)\)

然后套一下點分治或者\(dsu\ on\ tree\)都可以

code

#include<bits/stdc++.h> #include<algorithm> #include<iostream> #include<cstdlib> #include<iomanip> #include<cstring> #include<complex> #include<vector> #include<cstdio> #include<string> #include<bitset> #include<ctime> #include<cmath> #include<queue> #include<stack> #include<map> #include<set> #define FILE "a" #define mp make_pair #define pb push_back #define RG register #define il inline using namespace std; typedef unsigned long long ull; typedef vector<int>VI; typedef long long ll; typedef double dd; const dd eps=1e-10; const int mod=1e9+7; const int N=510; const int M=4010; const dd pi=acos(-1); const int inf=mod; const ll INF=1e18+1; const ll P=100000; il ll read(){RG ll data=0,w=1;RG char ch=getchar();while(ch!='-'&&(ch<'0'||ch>'9'))ch=getchar();if(ch=='-')w=-1,ch=getchar();while(ch<='9'&&ch>='0')data=data*10+ch-48,ch=getchar();return data*w; }il void file(){srand(time(NULL)+rand());freopen(FILE".in","r",stdin);freopen(FILE".out","w",stdout); }int n,m,w[N],c[N],d[N],ans; int head[N],nxt[N<<1],to[N<<1],cnt; int sz[N],son[N],dfn[N],fw[N],cntw; void dfs1(int u,int fa){sz[u]=1;son[u]=0;for(RG int i=head[u];i;i=nxt[i]){RG int v=to[i];if(v==fa)continue;dfs1(v,u);sz[u]+=sz[v];if(sz[son[u]]<sz[v])son[u]=v;} } void dfs2(int u,int fa){dfn[u]=++cntw;fw[cntw]=u;for(RG int i=head[u];i;i=nxt[i]){RG int v=to[i];if(v==fa||v==son[u])continue;dfs2(v,u);}if(son[u])dfs2(son[u],u); }int dp[N][M],q[M],l,r; il void upd(int &a,int b){a=a>b?a:b;} il void work(int *f1,int *f2,int u){for(RG int i=0,ret;i<c[u];i++){l=1;r=0;for(RG int j=0;j*c[u]+i<=m;j++){while(l<=r&&j-q[l]>d[u])l++;ret=l>r?-inf:f2[q[l]*c[u]+i]+(j-q[l])*w[u];upd(f1[j*c[u]+i],ret);while(l<=r&&f2[q[r]*c[u]+i]<=f2[j*c[u]+i]+(q[r]-j)*w[u])r--;q[++r]=j;}} }void dsu(int u,int fa,int k){for(RG int i=head[u];i;i=nxt[i]){RG int v=to[i];if(v==fa||v==son[u])continue;dsu(v,u,0);}if(son[u])dsu(son[u],u,1);for(RG int i=0;i<=m;i++)dp[fw[dfn[u]+sz[u]]][i]=-inf;dp[fw[dfn[u]+sz[u]]][0]=0;for(RG int i=dfn[u]+sz[u]-sz[son[u]]-1;i>=dfn[u];i--){RG int x=fw[i];for(RG int j=0;j<=m;j++)dp[x][j]=-inf;if(x!=u)for(RG int j=0;j<=m;j++)upd(dp[x][j],dp[fw[i+sz[x]]][j]);work(dp[x],dp[fw[i+1]],x);}for(RG int i=0;i<=m;i++)upd(ans,dp[u][i]);if(k){for(RG int i=0;i<=m;i++)dp[u][i]=-inf;for(RG int i=0;i<=m;i++)upd(dp[u][i],dp[fw[dfn[u]+sz[u]]][i]);work(dp[u],dp[fw[dfn[u]+1]],u);} }int main() {RG int T=read();while(T--){n=read();m=read();ans=-inf;fw[n+1]=n+1;cnt=cntw=0;memset(head,0,sizeof(head));for(RG int i=1;i<=n;i++)w[i]=read();for(RG int i=1;i<=n;i++)c[i]=read();for(RG int i=1;i<=n;i++)d[i]=read();for(RG int i=1,u,v;i<n;i++){u=read();v=read();to[++cnt]=v;nxt[cnt]=head[u];head[u]=cnt;to[++cnt]=u;nxt[cnt]=head[v];head[v]=cnt;} dfs1(1,0);dfs2(1,0);dsu(1,0,0); printf("%d\n",ans);}return 0; }

轉載于:https://www.cnblogs.com/cjfdf/p/9540057.html

總結

以上是生活随笔為你收集整理的[BZOJ4182]Shopping的全部內容,希望文章能夠幫你解決所遇到的問題。

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

主站蜘蛛池模板: 国产日韩一级片 | 日本中文字幕免费观看 | 干老太太视频 | 国产视频一区二区三区在线播放 | 手机在线一区二区三区 | 波多野结衣加勒比 | 日韩porn| 日韩成人精品 | 国内精品在线播放 | 人妻少妇一区二区 | 丁香婷婷亚洲 | 国产精品高潮呻吟久久aⅴ码 | 欧美一级三级 | 中文天堂在线视频 | 午夜影视免费 | 亚洲天堂2021av | 久久综合久久综合久久 | 日韩欧美精品中文字幕 | 中文字幕一区二区三区手机版 | 四虎一级片| 国产老肥熟 | 亚洲福利视频一区二区 | 日韩欧美网址 | 大尺度网站在线观看 | 在线成人免费电影 | 日韩天堂网 | 国产一级淫片a | 国产尤物网站 | 国产色无码精品视频国产 | 自拍偷拍亚洲图片 | 视频1区2区 | 高清国产在线 | 黄色免费av | 天堂福利视频 | 99精品视频一区二区 | sese视频在线观看 | 日韩av资源| 6090伦理 | 精品久久久亚洲 | 午夜成人鲁丝片午夜精品 | 国产又粗又大又硬 | 亚洲精品视频导航 | 无码国产精品一区二区色情男同 | 中文字幕第一页在线播放 | 久久综合九色综合欧美狠狠 | 日本美女交配 | 国产乱仑视频 | 高清在线一区二区三区 | www.涩涩爱 | 国产精品自拍一区 | av导航在线 | 天天色综合色 | jzzijzzij亚洲成熟少妇在线观看 久久久精品人妻一区二区三区 | 五月天在线 | 成人午夜网址 | 成人网站在线进入爽爽爽 | 成人另类小说 | 国产在线网 | 99视屏 | 欧美色第一页 | 欧美永久免费 | 91精品国产高清 | 国产熟女一区二区丰满 | 玉女心经 在线 | 色窝网 | 韩国一级一片高清免费观看 | 爽爽爽av| 亚洲婷婷免费 | 欧美精品午夜 | 欧美综合另类 | 性欧美bbw | 久草香蕉视频 | 网站av| 精品美女久久 | 小明看国产 | av五十路| 亚洲综合视频在线观看 | 亚洲人成免费 | 99热这里只有精品8 国产一卡二 | 久久艹伊人 | 久久久久久综合网 | 夜夜操天天操 | 一本色道久久88综合日韩精品 | 国产精品福利小视频 | 老司机免费视频 | 日韩高清精品免费观看 | 免费性情网站 | 四虎网址在线 | 国产性爱精品视频 | 乱色视频 | 国产精品大片 | 亚洲一区电影 | 在线免费播放av | 国模无码视频一区二区三区 | 日韩国产一区二区三区 | 国产精品果冻传媒 | 日日噜噜噜夜夜爽爽狠狠视频97 | 中文字幕人妻丝袜乱一区三区 | 性高潮久久久久久久久久 |