#include<cstdio>
#include<iostream>
#include<algorithm>
#include<cstring>
#include<cmath>
#include<queue>
using namespace std;
const int MAXN=;
int rmq[*MAXN];//rmq数组,就是欧拉序列对应的深度序列
struct ST
{
int mm[*MAXN];
int dp[*MAXN][];//最小值对应的下标
void init(int n)
{
mm[]=-;
for(int i=;i<=n;i++)
{
mm[i]=((i&(i-))==)?mm[i-]+:mm[i-];
dp[i][]=i;
}
for(int j=;j<=mm[n];j++)
for(int i=;i+(<<j)-<=n;i++)
dp[i][j]=rmq[dp[i][j-]]<rmq[dp[i+(<<(j-))][j-]]?dp[i][j-]:dp[i+(<<(j-))][j-];
}
int query(int a,int b)//查询[a,b]之间最小值的下标
{
if(a > b)swap(a,b);
int k=mm[b-a+];
return rmq[dp[a][k]]<=rmq[dp[b-(<<k)+][k]]?dp[a][k]:dp[b-(<<k)+][k];
}
};
//边的结构体定义
struct Edge
{
int to,next;
};
Edge edge[MAXN*];
int tot,head[MAXN];
int F[MAXN*];//欧拉序列,就是dfs遍历的顺序,长度为2*n-1,下标从1开始
int P[MAXN];//P[i]表示点i在F中第一次出现的位置
int cnt;
ST st;
void init()
{
tot=;
memset(head,-,sizeof(head));
}
void addedge(int u,int v)//加边,无向边需要加两次
{
edge[tot].to=v;
edge[tot].next=head[u];
head[u]=tot++;
}
void dfs(int u,int pre,int dep)
{
F[++cnt]=u;
rmq[cnt]=dep;
P[u]=cnt;
for(int i=head[u];i!=-;i=edge[i].next)
{
int v=edge[i].to;
if(v==pre)continue;
dfs(v,u,dep+);
F[++cnt]=u;
rmq[cnt]=dep;
}
}
void LCA_init(int root,int node_num)//查询LCA前的初始化
{
cnt=;
dfs(root,root,);
st.init(*node_num-);
}
int query_lca(int u,int v)//查询u,v的lca编号
{
return F[st.query(P[u],P[v])];
}
bool flag[MAXN];
int main()
{
#ifndef ONLINE_JUDGE
freopen("1.in","r",stdin);
#endif
int T;
int N;
int u,v;
scanf("%d",&T);
while(T--)
{
scanf("%d",&N);
init();
memset(flag,false,sizeof(flag));
for(int i=;i<N;i++)
{
scanf("%d%d",&u,&v);
addedge(u,v);
addedge(v,u);
flag[v]=true;
}
int root;
for(int i=;i<=N;i++)
if(!flag[i])
{
root=i;
break;
}
LCA_init(root,N);
scanf("%d%d",&u,&v);
printf("%d\n",query_lca(u,v));
}
return ;
}

最新文章

  1. coreData部分报错:This NSPersistentStoreCoordinator has no persistent stores.
  2. [No000016]为什么假期计划总是做不到?
  3. Oracle安装步骤及PL/SQL Developer连接数据库
  4. 轮子来袭 vJine.Core Orm 之 04_使用进阶
  5. MachineKey
  6. svn出错问题(用户名密码有修改以及资源url改变时)
  7. MSSQL存储过程(好久的笔记,翻出来怀念下)
  8. ArrayList的toArray
  9. HTML浅识
  10. ios中的银联支付
  11. cocos2dx进阶学习之CCTMXTiledMap
  12. scanf和cin性能的比较
  13. 理解bootstrap的列偏移offset 和 推拉push/pull的区别?
  14. 《Linux 性能及调优指南》1.1 Linux进程管理
  15. 【CSS3】好玩的动画线框
  16. Java并发笔记-未完待续待详解
  17. Vue路由scrollBehavior滚动行为控制锚点
  18. Python 全栈开发:day3 作业与默写
  19. Delphi在Android下实现BroadcastReceiver功能(举例在Delphi下获取USB外设拔插消息)
  20. dubbo初探(转载)

热门文章

  1. iOS项目工作空间搭建
  2. [LeetCode] Word Ladder II
  3. 新浪微博客户端(5)-自定义UISearchBar
  4. linux 下如何给用户添加权限
  5. Ubuntu 12.04 安装 Chrome浏览器
  6. cocos进阶教程(3)Cocos2d-x多场景切换生命周期
  7. 在docker里面安装部署应用
  8. mysql启动报错(mac)
  9. gem install factory_girl
  10. 【数据库】如家汉庭酒店2000万开房数据1.71G/BAK,792M/CSV