本来觉得这是一道挺水的题目,后来觉得出题人挺变态的= =

半个小时敲完后,内存超限它给我看TLE,还是0ms,后来才发现内存限制64m

然后卡了一个小时后AC了。。

题目大意是在一棵树上找三点的最短路

依次挑两个点求LCA,再将LCA与第三个点再求LCA

求三次取最优就行了。

 #include<stdio.h>
 #include<string.h>
 #include<algorithm>
 using namespace std;
 ;
 struct node{
     int to,next;
 }e[];
 int sum,n,m,tot,logn,l,r,a,b,c,x,y,id;
 ],dep[maxn];

 void insert(int u, int v, int c){
     e[++tot].to=v;
     //e[tot].cost=c;
     e[tot].next=head[u];
     head[u]=tot;
 }

 void dfs(int u, int f, int d){
     dep[u]=d;
     fa[u][]=f; //dis[u][0]=c;
     ; i<=logn; i++) fa[u][i]=fa[fa[u][i-]][i-];
     //for (int i=1; i<=logn; i++) dis[u][i]=dis[u][i-1]+dis[fa[u][i-1]][i-1];
     ; i=e[i].next)
         if (e[i].to!=f)
             dfs(e[i].to,u,d+);
 }

 int lca(int u, int v){
     if (dep[u]>dep[v]) swap(u,v);
     while (dep[u]<dep[v]){
         ; i--)
             if (dep[u]<dep[fa[v][i]]){
                 //sum+=dis[v][i];
                 v=fa[v][i];
             }
         //sum+=dis[v][0];
         v=fa[v][];
     }
     if (u==v) return u;
     ; i--)
         if (fa[u][i]!=fa[v][i]){
         //    sum+=dis[v][i]+dis[u][i];
             u=fa[u][i]; v=fa[v][i];
         }
     //sum+=dis[v][0]+dis[u][0];
     u=fa[u][]; v=fa[v][];
     return u;
 }

 int main(){
     scanf("%d%d", &n, &m);
     tot=-;
     ; i<=n; i++) head[i]=-;
      //memset(head,-1,sizeof(head));
     //memset(dis,0,sizeof(dis));
     //memset(e,0,sizeof(e));
     ; i<n; i++){
         scanf("%d%d", &l, &r);
         insert(l,r,);
         insert(r,l,);
     }
     logn=;
     <<logn)<n) logn++;
     dfs(,,);
     ; i<=m; i++){
         scanf("%d%d%d", &a, &b, &c);
         ;
         x=lca(a,b); y=lca(x,c);
         sum=dep[a]+dep[b]+dep[c]-dep[x]-dep[y]*;
         if (sum<ans){
             ans=sum;
             id=x;
         }
         x=lca(a,c); y=lca(x,b);
         sum=dep[a]+dep[b]+dep[c]-dep[x]-dep[y]*;
         if (sum<ans){
             ans=sum;
             id=x;
         }
         x=lca(b,c); y=lca(x,a);
         sum=dep[a]+dep[b]+dep[c]-dep[x]-dep[y]*;
         if (sum<ans){
             ans=sum;
             id=x;
         }
         printf("%d %d\n", id, ans);
     }
     ;
 }

bzoj1832: [AHOI2008]聚会--LCA的更多相关文章

  1. bzoj1787[Ahoi2008]Meet 紧急集合&bzoj1832[AHOI2008]聚会

    bzoj1787[Ahoi2008]Meet 紧急集合 bzoj1832[AHOI2008]聚会 题意: 给个树,每次给三个点,求与这三个点距离最小的点. 题解: 倍增求出两两之间的LCA后,比较容易 ...

  2. bzoj1832: [AHOI2008]聚会

    写过的题... #include<cstdio> #include<cstring> #include<iostream> #include<algorith ...

  3. BZOJ 1832: [AHOI2008]聚会( LCA )

    LCA模板题...不难发现一定是在某2个人的LCA处集合是最优的, 然后就3个LCA取个最小值就OK了. 距离就用深度去减一减就可以了. 时间复杂度O(N+MlogN) (树链剖分) -------- ...

  4. 题解 [BZOJ1832][AHOI2008] 聚会

    题面 解析 首先对于其中的两个点\(x,y\)最近的点显然就是他们的\(lca\)(我们把它设为\(p1\)), 然后考虑第三个点\(z\)与\(p1\)的\(lca,p2\). 有以下几种情况: \ ...

  5. P4281 [AHOI2008]紧急集合 / 聚会[LCA]

    解析 蒟蒻用的办法比较蠢,不如上面的各位大佬,直接化成一个式子了,我还是分类讨论做的. 下面正文. 猜想:最优集合点一定是三点任意两对点对应的路径的交点. 不妨这样想,如果任意两个人经过同一条路径,那 ...

  6. LUOGU P4281 [AHOI2008]紧急集合 / 聚会 (lca)

    传送门 解题思路 可以通过手玩或打表发现,其实要选的点一定是他们三个两两配对后其中一对的$lca$上,那么就直接算出来所有的$lca$,比较大小就行了. #include<iostream> ...

  7. bzoj 1787 [Ahoi2008]Meet 紧急集合(1832 [AHOI2008]聚会)

    1787: [Ahoi2008]Meet 紧急集合 Time Limit: 20 Sec  Memory Limit: 162 MBSubmit: 1841  Solved: 857[Submit][ ...

  8. 【BZOJ】1832: [AHOI2008]聚会

    题目链接:http://www.lydsy.com/JudgeOnline/problem.php?id=1832 省选出出了CF的感觉..... 显然一发贪心,如果两个点显然就是他们的$LCA$(不 ...

  9. bzoj 1832: [AHOI2008]聚会

    良心题2333 三个点两两求一遍就行,最小肯定是在某2个点的lca处,(肯定让第三个人去找2个人,不能让2个人一起去找第三个人233) #include<bits/stdc++.h> #d ...

随机推荐

  1. Javaweb三大组件之过滤器filter

    Filter的三个方法 void init(FilterConfig):在Tomcat启动时被调用: void destroy():在Tomcat关闭时被调用: void doFilter(Servl ...

  2. C#中Process类的使用

    本文来自: http://www.cnblogs.com/kay/archive/2008/11/25/1340387.html Process 类的作用是对系统进程进行管理,我们使用Process类 ...

  3. Android打包的那些事

    使用gradle打包apk已经成为当前主流趋势,我也在这个过程中经历了各种需求,并不断结合gradle新的支持,一一改进.在此,把这些相关的东西记录,做一总结. 1. 替换AndroidManifes ...

  4. hdu2859 dp

    题目链接:http://acm.split.hdu.edu.cn/showproblem.php?pid=2859 题意:输入一个数n,接下来是一个由n*n个字母组成的矩阵,求以左下到右上的线为轴的最 ...

  5. JQuery学习之操作DOM

    1.DOM,就是Document Object Model(文档对象模型) 2.获得内容的方法: **text():设置或返回所选元素的文本内容 $("#btn1").click( ...

  6. DSP using MATLAB 示例Example3.7

    上代码: x1 = rand(1,11); x2 = rand(1,11); n = 0:10; alpha = 2; beta = 3; k = 0:500; w = (pi/500)*k; % [ ...

  7. [工作中的设计模式]观察者模式observer

    一.模式解析 观察者模式定义了一种一对多的依赖关系,让多个观察者对象同时监听某一个主题对象.这个主题对象在状态上发生变化时,会通知所有观察者对象,使它们能够自动更新自己. 观察者模式又叫订阅发布模式, ...

  8. 简单的实现UIpicker上面的取消确定按钮

    1 因为我用的xib实现的添加picker 和textfiled的, @interface ViewController : UIViewController<UITextFieldDelega ...

  9. Android实现全屏的三种方式

    一.通过代码 requestWindowFeature(Window.FEATURE_NO_TITLE);// 隐藏标题栏 getWindow().setFlags(WindowManager.Lay ...

  10. BZOJ4367 : [IOI2014]holiday假期

    设 $fl[i]$表示从$S$向左走,用了不超过$i$天且不回头的最大收益. $fr[i]$表示从$S$向右走,用了不超过$i$天且不回头的最大收益. $gl[i]$表示从$S$向左走,用了不超过$i ...