果然我已经菜到被\(div3\)的题虐哭了

qwq

首先看到这个题,一个比较显然的想法就是先从1号点开始\(dfs\)一遍,然后通过一些奇怪的方式,再\(dfs\)一遍得到其他点的贡献。

那么具体应该这么做呢。

首先,我们维护两个数组\(dis[i]\)表示\(i\)到1的距离,\(sum[i]\)表示\(i\)的子树中的\(val\)的和。

然后我们考虑,如果从\(fa[x]\)移动到\(x\),相当于\(x\)的子树内的\(dis\)都要减一,对\(ans\)的贡献是\(-sum[x]\),然后\(x\)的子树外面的所有的点的\(dis\)要加一,对\(ans\)的贡献是\(sum[1]-sum[x]\)。

那么我们只需要两遍\(dfs\),第二遍\(dfs\),一边\(dfs\)一边更新\(ans\)就好。

  1. #include<bits/stdc++.h>
  2. #define mk make_pair
  3. #define pb push_back
  4. #define ll long long
  5. #define int long long
  6. using namespace std;
  7. inline int read()
  8. {
  9. int x=0,f=1;char ch=getchar();
  10. while (!isdigit(ch)) {if (ch=='-') f=-1;ch=getchar();}
  11. while (isdigit(ch)) {x=(x<<1)+(x<<3)+ch-'0';ch=getchar();}
  12. return x*f;
  13. }
  14. const int maxn = 4e5+1e2;
  15. const int maxm = 2*maxn;
  16. int point[maxn],nxt[maxm],to[maxm];
  17. int dis[maxn],sum[maxn];
  18. int ans;
  19. int n,m,cnt;
  20. int tmp;
  21. int val[maxn];
  22. void addedge(int x,int y)
  23. {
  24. nxt[++cnt]=point[x];
  25. to[cnt]=y;
  26. point[x]=cnt;
  27. }
  28. void dfs(int x,int fa,int dep)
  29. {
  30. sum[x]=val[x];
  31. dis[x]=dep;
  32. for (int i=point[x];i;i=nxt[i])
  33. {
  34. int p = to[i];
  35. if(p==fa) continue;
  36. dfs(p,x,dep+1);
  37. sum[x]+=sum[p];
  38. }
  39. }
  40. void solve(int x,int fa,int now)
  41. {
  42. ans=max(ans,now);
  43. for (int i=point[x];i;i=nxt[i])
  44. {
  45. int p=to[i];
  46. if (p==fa) continue;
  47. solve(p,x,now+sum[1]-sum[p]-sum[p]);
  48. }
  49. }
  50. signed main()
  51. {
  52. n=read();
  53. for (int i=1;i<=n;i++) val[i]=read();
  54. for (int i=1;i<n;i++)
  55. {
  56. int x=read(),y=read();
  57. addedge(x,y);
  58. addedge(y,x);
  59. }
  60. dfs(1,0,0);
  61. for (int i=1;i<=n;i++) tmp=tmp+dis[i]*val[i];
  62. ans=tmp;
  63. //cout<<ans<<endl;
  64. solve(1,0,tmp);
  65. cout<<ans;
  66. return 0;
  67. }

CF1092F Tree with Maximum Cost(dfs+dp)的更多相关文章

  1. Codeforces 1092F Tree with Maximum Cost(树形DP)

    题目链接:Tree with Maximum Cost 题意:给定一棵树,树上每个顶点都有属性值ai,树的边权为1,求$\sum\limits_{i = 1}^{n} dist(i, v) \cdot ...

  2. Codeforces Round #527 (Div. 3) F. Tree with Maximum Cost 【DFS换根 || 树形dp】

    传送门:http://codeforces.com/contest/1092/problem/F F. Tree with Maximum Cost time limit per test 2 sec ...

  3. 2018.12.19 codeforces 1092F. Tree with Maximum Cost(换根dp)

    传送门 sbsbsb树形dpdpdp题. 题意简述:给出一棵边权为1的树,允许选任意一个点vvv为根,求∑i=1ndist(i,v)∗ai\sum_{i=1}^ndist(i,v)*a_i∑i=1n​ ...

  4. CF1092 --- Tree with Maximum Cost

    CF1324 --- Maximum White Subtree 题干 You are given a tree consisting exactly of \(n\) vertices. Tree ...

  5. CF F - Tree with Maximum Cost (树形DP)给出你一颗带点权的树,dist(i, j)的值为节点i到j的距离乘上节点j的权值,让你任意找一个节点v,使得dist(v, i) (1 < i < n)的和最大。输出最大的值。

    题目意思: 给出你一颗带点权的树,dist(i, j)的值为节点i到j的距离乘上节点j的权值,让你任意找一个节点v,使得dist(v, i) (1 < i < n)的和最大.输出最大的值. ...

  6. Codeforces Round #527 F - Tree with Maximum Cost /// 树形DP

    题目大意: 给定一棵树 每个点都有点权 每条边的长度都为1 树上一点到另一点的距离为最短路经过的边的长度总和 树上一点到另一点的花费为距离乘另一点的点权 选定一点出发 使得其他点到该点的花费总和是最大 ...

  7. Codeforces 1092 F Tree with Maximum Cost (换根 + dfs)

    题意: 给你一棵无根树,每个节点有个权值$a_i$,指定一个点u,定义$\displaystyle value = \sum^v a_i*dist(u,v)$,求value的最大值 n,ai<= ...

  8. Is It A Tree?(并查集)(dfs也可以解决)

    Is It A Tree? Time Limit:1000MS     Memory Limit:10000KB     64bit IO Format:%I64d & %I64u Submi ...

  9. HDU1078 FatMouse and Cheese(DFS+DP) 2016-07-24 14:05 70人阅读 评论(0) 收藏

    FatMouse and Cheese Problem Description FatMouse has stored some cheese in a city. The city can be c ...

随机推荐

  1. 多线程-synchorized

    synchorized锁升级过程: synchorized锁升级过程中只能升级不能降级,起初是JDK早期(1.5之前),是重量级锁,是找操作系统申请OS锁.所谓重量级锁是说获取锁和释放锁都需要经过操作 ...

  2. PB代码转JAVA工具

    开发了PB代码转JAVA的工具,正在做datawindow和datastore的处理.以下是目前已经能处理的功能: 1.自动从PBL中获取对象的函数或事件代码 a)可以自动获取实例变量.函数或事件的入 ...

  3. 移动端常用单位——rem

    移动端常用单位: ①px:像素大小,固定值 ②%:百分比 ③em(不常用,但是在首行缩进时可以使用):相对自身的font大小(当自身的字体大小也是em做单位时,才会以父元素的字体大小为基准单位) ④r ...

  4. 跨平台APP推荐收藏

    时间:2019-04-11 整理:pangYuaner 标题:十大跨平台优秀软件 地址:https://www.cnblogs.com/the-king-of-cnblogs/p/3154758.ht ...

  5. python matplotlib 绘图+显示数值

    参考:https://www.jb51.net/article/152685.htm 用plt.text函数 import numpy as np import matplotlib.mlab as ...

  6. 基于Linux系统下Apache服务器的安装部署

    企业中常用的web服务,用来提供http://(超文本传输协议). web系统是客户端/服务器模式的,所以应该有服务器和客户端里两个部分.常用的服务器程序时Apache,常用的客户端程序是浏览器.ww ...

  7. vue element-ui 组件上传图片 以及对 图片的 宽高 和 大小 格式等 做出限制

    vue  文件: 自行引用 elemen-ui    <el-upload                         action=" 让后端给你上传地址 "      ...

  8. Django——ORM打印SQL

    如果想打印ORM转换过程中的SQL,需要在settings.py中进行如下配置: LOGGING = { 'version': 1, 'disable_existing_loggers': False ...

  9. K8S——Pod

    一.Pod概念 二.Pod存在的意义 三.Pod的实现机制 四.Pod镜像拉取策略 五.Pod资源限制 六.Pod重启机制 七.Pod的健康检查 八.Pod调度策略(创建Pod流程)

  10. WHY IS A BYTE 8 BITS? OR IS IT?

    WHY IS A BYTE 8 BITS? OR IS IT? 原文链接:http://www.bobbemer.com/BYTE.HTM I recently received an e-mail ...