E87 换根DP CF1187E Tree Painting
视频链接:E87 换根DP CF1187E Tree Painting_哔哩哔哩_bilibili
CF1187E Tree Painting - 洛谷 | 计算机科学教育新生态 (luogu.com.cn)
// 换根DP O(n) #include <iostream> #include <cstring> #include <algorithm> #include <vector> using namespace std; const int N=200010; vector<int> e[N]; int n; long long sz[N],f[N],ans; void dfs(int u,int fa){ sz[u]=1; for(int v:e[u]){ if(v==fa)continue; dfs(v,u); sz[u]+=sz[v]; } f[1]+=sz[u]; } void dfs2(int u,int fa){ for(int v:e[u]){ if(v==fa)continue; f[v]=f[u]-sz[v]+n-sz[v]; ans=max(ans,f[v]); dfs2(v,u); } } int main(){ scanf("%d",&n); for(int i=1,u,v;i<n;i++){ scanf("%d%d",&u,&v); e[u].push_back(v); e[v].push_back(u); } dfs(1,0); dfs2(1,0); printf("%lld",ans); }
// 换根DP O(n) #include <iostream> #include <cstring> #include <algorithm> #include <vector> using namespace std; const int N=200010; vector<int> e[N]; int n; long long sz[N],f[N],ans; void dfs(int u,int fa){ sz[u]=1; for(int v:e[u]){ if(v==fa)continue; dfs(v,u); sz[u]+=sz[v]; f[u]+=f[v]; } f[u]+=sz[u]; } void dfs2(int u,int fa){ for(int v:e[u]){ if(v==fa)continue; f[v]=f[u]-sz[v]+n-sz[v]; ans=max(ans,f[v]); dfs2(v,u); } } int main(){ scanf("%d",&n); for(int i=1,u,v;i<n;i++){ scanf("%d%d",&u,&v); e[u].push_back(v); e[v].push_back(u); } dfs(1,0); dfs2(1,0); printf("%lld",ans); }
分类:
E 动态规划
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 物流快递公司核心技术能力-地址解析分单基础技术分享
· 单线程的Redis速度为什么快?
· 展开说说关于C#中ORM框架的用法!
· Pantheons:用 TypeScript 打造主流大模型对话的一站式集成库
· SQL Server 2025 AI相关能力初探
2023-12-03 C74 动态DP+树剖 P5024 [NOIP2018 提高组] 保卫王国