E72 换根DP P3047 [USACO12FEB] Nearby Cows G
视频链接:E72 换根DP P3047 [USACO12FEB] Nearby Cows G_哔哩哔哩_bilibili
P3047 [USACO12FEB] Nearby Cows G - 洛谷 | 计算机科学教育新生态 (luogu.com.cn)
// 换根DP O(nk) #include <iostream> #include <cstring> #include <algorithm> using namespace std; int read(){ int x=0,f=1;char c=getchar(); while(!isdigit(c)){if(c=='-')f=-1;c=getchar();} while(isdigit(c)){x=x*10+c-'0';c=getchar();} return x*f; } #define N 100005 int idx,head[N]; struct E{int to,ne;}e[N<<1]; void add(int x,int y){ e[++idx]={y,head[x]};head[x]=idx; } int n,k,w[N]; int f[N][25]; void dfs(int u,int fa){ for(int i=0;i<=k;i++)f[u][i]=w[u]; for(int i=head[u];i;i=e[i].ne){ int v=e[i].to; if(v==fa)continue; dfs(v,u); for(int i=1;i<=k;i++) f[u][i]+=f[v][i-1]; } } void dfs2(int u,int fa){ for(int i=head[u];i;i=e[i].ne){ int v=e[i].to; if(v==fa)continue; for(int i=k;i>=2;i--) f[v][i]+=f[u][i-1]-f[v][i-2]; f[v][1]+=f[u][0]; dfs2(v,u); } } int main(){ n=read(),k=read(); for(int i=1,x,y;i<n;i++){ x=read(),y=read(); add(x,y);add(y,x); } for(int i=1;i<=n;i++) w[i]=read(); dfs(1,0); dfs2(1,0); for(int i=1;i<=n;i++) printf("%d\n",f[i][k]); }
分类:
E 动态规划
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 阿里最新开源QwQ-32B,效果媲美deepseek-r1满血版,部署成本又又又降低了!
· 单线程的Redis速度为什么快?
· SQL Server 2025 AI相关能力初探
· AI编程工具终极对决:字节Trae VS Cursor,谁才是开发者新宠?
· 展开说说关于C#中ORM框架的用法!
2023-10-26 C53 可持久化线段树+离散化 P2464 [SDOI2008] 郁闷的小 J
2023-10-26 C52 可持久化线段树 P1972 [SDOI2009] HH的项链