标题效果:给定一个树(直接将树。不要贪图生成树图!)。寻找每条边权值*分差的两侧之间

BFS水必须是能

竟DFS能够住。。。系统堆栈可能有些不够,我们可以使用内联汇编手册中大型系统堆栈 详见代码

这个问题读取优化可以优化掉4s右

  1. #include<cstdio>
  2. #include<cstring>
  3. #include<iostream>
  4. #include<algorithm>
  5. #define stack_size (20001000)
  6. #define M 1001001
  7. using namespace std;
  8. typedef long long ll;
  9. struct abcd{
  10. int to,f,next;
  11. }table[M<<1];
  12. int head[M],tot;
  13. int n,fa[M],f[M],siz[M],q[M],r,h;
  14. ll ans;
  15. int stack[stack_size],bak;
  16. void DFS(int x)
  17. {
  18. int i;
  19. siz[x]=1;
  20. for(i=head[x];i;i=table[i].next)
  21. {
  22. if(table[i].to==fa[x])
  23. continue;
  24. fa[table[i].to]=x;
  25. f[table[i].to]=table[i].f;
  26. DFS(table[i].to);
  27. siz[x]+=siz[table[i].to];
  28. }
  29. ans+=(ll)abs(siz[x]+siz[x]-n)*f[x];
  30. }
  31. void CallDFS()
  32. {
  33. __asm__ __volatile__
  34. (
  35. "mov %%esp,%0\n"
  36. "mov %1,%%esp\n"
  37. :"=g"(bak)
  38. :"g"(stack+stack_size-1)
  39. :
  40. );
  41. DFS(1);
  42. __asm__ __volatile__
  43. (
  44. "mov %0,%%esp\n"
  45. :
  46. :"g"(bak)
  47. :
  48. );
  49. }
  50. inline int getc() {
  51. static const int L = 1 << 15;
  52. static char buf[L], *S = buf, *T = buf;
  53. if (S == T) {
  54. T = (S = buf) + fread(buf, 1, L, stdin);
  55. if (S == T)
  56. return EOF;
  57. }
  58. return *S++;
  59. }
  60. inline int getint() {
  61. int c;
  62. while(!isdigit(c = getc()) && c != '-');
  63. bool sign = c == '-';
  64. int tmp = sign ? 0 : c - '0';
  65. while(isdigit(c = getc()))
  66. tmp = (tmp << 1) + (tmp << 3) + c - '0';
  67. return sign ? -tmp : tmp;
  68. }
  69. void Add(int x,int y,int z)
  70. {
  71. table[++tot].to=y;
  72. table[tot].f=z;
  73. table[tot].next=head[x];
  74. head[x]=tot;
  75. }
  76. int main()
  77. {
  78. int i,x,y,z;
  79. cin>>n;
  80. for(i=1;i<n;i++)
  81. {
  82. x=getint();
  83. y=getint();
  84. z=getint();
  85. Add(x,y,z);
  86. Add(y,x,z);
  87. }
  88. CallDFS();
  89. cout<<ans<<endl;
  90. }

版权声明:本文博主原创文章,博客,未经同意不得转载。

BZOJ 2435 NOI2011 道路建设 BFS/DFS的更多相关文章

  1. BZOJ 2435: [Noi2011]道路修建( dfs )

    NOI的水题...直接一遍DFS即可 ------------------------------------------------------------------------- #includ ...

  2. BZOJ 2435: [Noi2011]道路修建 dfs搜图

    2435: [Noi2011]道路修建 Description 在 W 星球上有 n 个国家.为了各自国家的经济发展,他们决定在各个国家之间建设双向道路使得国家之间连通.但是每个国家的国王都很吝啬,他 ...

  3. bzoj 2435: [Noi2011]道路修建 树上 dp

    2435: [Noi2011]道路修建 Time Limit: 20 Sec Memory Limit: 256 MB 题目连接 http://www.lydsy.com/JudgeOnline/pr ...

  4. bzoj 2435: [Noi2011]道路修建

    Description 在 W 星球上有 n 个国家.为了各自国家的经济发展,他们决定在各个国家 之间建设双向道路使得国家之间连通.但是每个国家的国王都很吝啬,他们只愿 意修建恰好 n – 1条双向道 ...

  5. bzoj 2435: [Noi2011]道路修建【树形dp】

    dp求size和deep,然后对每条边模拟求代价即可 #include<iostream> #include<cstdio> #include<algorithm> ...

  6. 2435: [Noi2011]道路修建

    2435: [Noi2011]道路修建 Time Limit: 10 Sec  Memory Limit: 128 MBSubmit: 2188  Solved: 639[Submit][Status ...

  7. 2435: [Noi2011]道路修建(树上操作)

    2435: [Noi2011]道路修建 题目:传送门 题解: 建完边之后以1为根建树,统计深度和各个点的子树大小(包括自己) 询问的时候:答案=长度*abs(n-深度大的点的子树大小*2) ans+= ...

  8. 【BZOJ】2435: [Noi2011]道路修建(树形dp)

    http://www.lydsy.com/JudgeOnline/problem.php?id=2435 我怎么感觉那么水.. 坑的是,dfs会爆...好吧..用bfs.. //upd:我的智商也是醉 ...

  9. 2435: [Noi2011]道路修建 - BZOJ

    Description 在 W 星球上有 n 个国家.为了各自国家的经济发展,他们决定在各个国家之间建设双向道路使得国家之间连通.但是每个国家的国王都很吝啬,他们只愿意修建恰好 n – 1条双向道路. ...

随机推荐

  1. (转)ikvmc的使用

    IKVM.NET是一个针对Mono和微软.net框架的java实现,其设计目的是在.NET平台上运行java程序.本文将比较详细的介绍这个工具的原理.使用入门(如何java应用转换为.NET应用.), ...

  2. 使用JS模拟出Map对象

    近期要做的一个项目,支持方提供的一个Map方法,用着相当能够,功能稍有欠缺,因此我为之做了扩展,下面是代码: function Map() { this.elements = new Array(); ...

  3. Hadoop里的Partitioner

    人们对于Mapreduce程序刚開始时都觉得仅仅须要一个reduce就够了. 毕竟,在你处理数据之前一个reducer已经把数据都分好类了,有谁不喜欢分好类的数据呢. 可是这样我们就忽略了并行计算的优 ...

  4. 道破Redis的VM

    原创文章是freas_1990.转载请注明出处:http://blog.csdn.net/freas_1990/article/details/42052813 Redis唯一的那个key的value ...

  5. EF 执行视图

    IEnumerable<V_stocks> summary = db.Database.SqlQuery<V_stocks>("SELECT * FROM dbo.V ...

  6. u-boot 的bootcmd 和bootargs详解,烧写分析

    下面链接这篇文章也非常重要,介绍DM3X的一系列烧写步骤和设置方法 http://www.61ic.com/Article/DaVinci/TMS320DM3x/201204/41827.html U ...

  7. 王立平--Failed to push selection: Read-only file system

    往android模拟器导入资源,失败. 提示:仅仅读文件. mnt是仅仅读文件.应点击sdcard.,在导入

  8. 在TextView中加入图片

    TextView是一个非常强大的控件,有时须要在一个控件中同一时候显示图片和文字,使用TextView非常easy实现. 方法一: 聊天软件比方QQ一般都会有发送表情的功能,使用SpannableSt ...

  9. 高速幂 POW优化

    #include <iostream> #include <stdio.h> #include <stdlib.h> #include <string.h&g ...

  10. IAR FOR ARM 各版本号,须要的大家能够收藏了

    首先感谢大家的支持与关注,如今应该又一次编辑这篇文章了,这篇文章是非常久曾经不知在什么地方Copy过来的, 非常多问题不知怎么解决,如今我用的是KEIL for arm. 用过Keil和IAR,个人感 ...