思路:

对于结点 u 的子节点 v, 如果已经一直到结点 u 的答案ans[u],那么转移到对于结点 v,num[v] 为 v为根的树的结点个数,那么对于结点v的答案相对于结点u的答案来说,

ans[v]=-num[v]*edge[u,v]+(n-num[v])*edge[u,v];

  1. //#include<bits/stdc++.h>
  2. #include<cstdio>
  3. #include<string.h>
  4. #include<algorithm>
  5. using namespace std;
  6. typedef pair<int,int> PII;
  7. typedef long long LL;
  8. #pragma comment(linker, "/STACK:10240000,10240000")
  9.  
  10. const int N=1e5+10;
  11.  
  12. struct asd{
  13. LL w;
  14. int to;
  15. int next;
  16. }e[N*2];
  17. int head[N],tol;
  18. LL n,ans[N];
  19. LL num[N];
  20.  
  21. void init()
  22. {
  23. tol=0;
  24. memset(head,-1,sizeof(head));
  25. memset(num,0,sizeof(num));
  26. memset(ans,0,sizeof(num));
  27. }
  28. void add(int u,int v)
  29. {
  30. e[tol].w=1;
  31. e[tol].to=v;
  32. e[tol].next=head[u];
  33. head[u]=tol++;
  34. }
  35.  
  36. bool vis[N];
  37. LL res;
  38. LL DFS(int u,LL weight)
  39. {
  40. num[u]=1LL;
  41. for(int i=head[u];~i;i=e[i].next)
  42. {
  43. int v=e[i].to;
  44. if(vis[v]) continue;
  45. res=res+weight+e[i].w;
  46. vis[v]=true;
  47. num[u]=num[u]+DFS(v,weight+e[i].w);
  48. }
  49. return num[u];
  50. }
  51.  
  52. void DFSS(int u)
  53. {
  54. for(int i=head[u];~i;i=e[i].next)
  55. {
  56. int v=e[i].to;
  57. if(vis[v]) continue;
  58. vis[v]=true;
  59. ans[v]=(n-num[v]*2LL)*e[i].w+ans[u];
  60. DFSS(v);
  61. }
  62. }
  63.  
  64. int main()
  65. {
  66. int u,v;
  67. scanf("%lld",&n);
  68. init();
  69. for(int i=1;i<n;i++){
  70. scanf("%d%d",&u,&v);
  71. add(u,v);add(v,u);
  72. }
  73.  
  74. memset(vis,false,sizeof(vis));
  75. vis[1]=true;
  76. res=0;
  77. num[1]=DFS(1,0);
  78. ans[1]=res;
  79.  
  80. memset(vis,false,sizeof(vis));
  81. vis[1]=true;
  82. DFSS(1);
  83.  
  84. for(int i=1;i<=n;i++)
  85. printf("%lld\n",ans[i]);
  86. return 0;
  87. }

51nod 1405【DFS】的更多相关文章

  1. 51nod 1416【DFS】

    思路: 暴力整个图,以这个为起点,然后看一下有没有找到一条路是会指向自己且元素个数>=4: #include <bits/stdc++.h> using namespace std; ...

  2. 【第40套模拟题】【noip2011_mayan】解题报告【map】【数论】【dfs】

    目录:1.潜伏者 [map] 2.Hankson的趣味题[数论]3.mayan游戏[dfs] 题目: 1. 潜伏者(spy.pas/c/cpp)[问题描述]R 国和S 国正陷入战火之中,双方都互派间谍 ...

  3. Kattis - glitchbot 【DFS】

    Kattis - glitchbot [DFS] 题意 有一个机器人 刚开始在(0, 0),然后给出一个目标点,并且会给出一系列指令,但是其中会有一个指令是错误的.我们需要找出那个指令,并且改成正确的 ...

  4. HDU 6113 度度熊的01世界 【DFS】(2017"百度之星"程序设计大赛 - 初赛(A))

    度度熊的01世界 Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)Total Su ...

  5. 【dfs】P1331 海战

    题目描述 在峰会期间,武装部队得处于高度戒备.警察将监视每一条大街,军队将保卫建筑物,领空将布满了F-2003飞机.此外,巡洋船只和舰队将被派去保护海岸线.不幸的是因为种种原因,国防海军部仅有很少的几 ...

  6. 【dfs】p1731 生日蛋糕

    1441:[例题2]生日蛋搞 [题目描述] 7月17日是Mr.W的生日,ACM-THU为此要制作一个体积为Nπ的M层生日蛋糕,每层都是一个圆柱体.设从下往上数第i(1≤i≤M)层蛋糕是半径为Ri, 高 ...

  7. 【dfs】LETTERS

    1212:LETTERS [题目描述] 给出一个roe×colroe×col的大写字母矩阵,一开始的位置为左上角,你可以向上下左右四个方向移动,并且不能移向曾经经过的字母.问最多可以经过几个字母. [ ...

  8. 洛谷P1605 迷宫【dfs】

    题目背景 迷宫 [问题描述] 给定一个N*M方格的迷宫,迷宫里有T处障碍,障碍处不可通过.给定起点坐标和 终点坐标,问: 每个方格最多经过1次,有多少种从起点坐标到终点坐标的方案.在迷宫 中移动有上下 ...

  9. 【dfs】BZOJ1703-[Usaco2007 Mar]Ranking the Cows 奶牛排名

    [题目大意] 农夫约翰有N(1≤N≤1000)头奶牛,每一头奶牛都有一个确定的独一无二的正整数产奶率.约翰想要让这些奶牛按产奶率从高到低排序,约翰已经比较了M(1≤M≤10000)对奶牛的产奶率,但他 ...

随机推荐

  1. Progressive Web App是一个利用现代浏览器的能力来达到类似APP的用户体验的技术——不就是chrome OS吗?

    什么是Progressive Web App? Progressive Web App是一个利用现代浏览器的能力来达到类似APP的用户体验的技术,由Google实现,让浏览器打开的网址像APP一样运行 ...

  2. Python习题-输出一个字符串中最长的子字符串及其长度

    描述:有个字符串$sd1#111$svda123!!!221&eSSDSDG,包含特殊字符.数字和字母,输出最长的子字符串和他的长度#例如上面的字符串包含数字字母的字符串是svda123,长度 ...

  3. 并发问题引出ThreadLocal

    ThreadLocal Thread-->人类Runnable-->任务类 多线程并发问题引出ThreadLocal 多线程并发问题的原因: 操作同一个对象,对对象具有读写权限(只读如拍照 ...

  4. 04 - Django应用第一步

    知识点 1) 创建项目命令 以及项目结构介绍 2) 创建应用程序命令 应用, 项目的区别 以及应用程序结构 3) 启动项目命令 4) URLs的编写 include()的使用 get发送参数的格式 u ...

  5. Ubuntu 下安装mysql

    本文引用自 https://www.cnblogs.com/jpfss/p/7944622.html 此篇为http://www.cnblogs.com/EasonJim/p/7139275.html ...

  6. ACM学习历程—FZU2195 检查站点(树形DP || 贪心)

    Description 在山上一共有N个站点需要检查,检查员从山顶出发去各个站点进行检查,各个站点间有且仅有一条通路,检查员下山前往站点时比较轻松,而上山时却需要额外的时间,问最后检查员检查完所有站点 ...

  7. JS图表工具 ---- Highcharts

    Highcharts 是一个用纯 JavaScript编写的一个图表库, 能够很简单便捷的在web网站或是 web 应用程序添加有交互性的图表,并且免费提供给个人学习.个人网站和非商业用途使用. Hi ...

  8. android开发 如何通过web服务器访问MYSQL数据库并且使其数据同步到android SQLite数据库?

    通过web服务器访问MYSQL数据库有以下几个过程: 1.在MySql下创建自己的数据库和自己的表单 2.连接数据库. 3.访问数据库 1.创建web工程 (服务器端) 在Myeclipse下新建一个 ...

  9. 问题6:如何让字典保持有序(使用collections的OrderedDict方法)

    from collections imort OrderedDict d = OrderedDict() d['aa'] = (1, 30) d['bb'] = (2, 31) d['cc'] = ( ...

  10. DTP模型之一:(XA协议之一)XA协议、二阶段2PC、三阶段3PC提交

    XA协议 XA是一个分布式事务协议,由Tuxedo提出.XA中大致分为两部分:事务管理器和本地资源管理器.其中本地资源管理器往往由数据库实现,比如Oracle.DB2这些商业数据库都实现了XA接口,而 ...