写这么长了不A有点舍不得。。

想A又调不出来。。

于是乎就存一下..

屠龙宝刀点击就送

#include <cstdio>
#include <vector>
#define N 205000
using namespace std;
vector<int>Graph[N];
int max(int a,int b) {return a>b?a:b;}
int min(int a,int b) {return a>b?b:a;}
int Pri[N],n,m,dep[N],dad[N][],Max[N][],Min[N][],up[N][],down[N][];
void dfs(int x)
{
dep[x]=dep[dad[x][]]+;
for(int i=;dad[x][i];++i)
{
Max[x][i+]=max(Max[x][i],Max[dad[x][i]][i]);
Min[x][i+]=min(Min[x][i],Min[dad[x][i]][i]);
up[x][i+]=max(up[x][i],Max[dad[x][i]][i]-Min[x][i]);
up[x][i+]=max(up[x][i],up[dad[x][i]][i]);
down[x][i+]=max(down[x][i],down[dad[x][i]][i]);
down[x][i+]=max(down[x][i],Max[x][i]-Min[dad[x][i]][i]);
dad[x][i+]=dad[dad[x][i]][i];
}
for(int i=;i<Graph[x].size();++i)
{
int v=Graph[x][i];
if(dad[x][]!=v)
{
dad[v][]=x;
Max[v][]=max(Pri[x],Pri[v]);
Min[v][]=min(Pri[x],Pri[v]);
up[v][]=max(,Pri[x]-Pri[v]);
down[v][]=min(,Pri[v]-Pri[x]);
dfs(v);
}
}
}
int lca(int x,int y)
{
if(dep[x]>dep[y]) swap(x,y);
for(int i=;i>=;--i)
if(dep[dad[y][i]]>=dep[x]) y=dad[y][i];
if(x==y) return x;
for(int i=;i>=;--i)
if(dad[y][i]!=dad[x][i]) x=dad[x][i],y=dad[y][i];
return dad[x][];
}
int Up(int x,int y)
{
int ret=,Minn=0x7fffffff;
if(dep[x]>dep[y]) swap(x,y);
for(int i=;i>=;--i)
{
if(dep[dad[y][i]]>=dep[x])
{
ret=max(ret,up[y][i]);
ret=max(ret,Max[y][i]-Minn);
Minn=min(Minn,Min[y][i]);
y=dad[y][i];
}
}
if(x==y) return ret;
for(int i=;i>=;--i)
{
if(dad[y][i]!=dad[x][i])
{
ret=max(ret,max(up[y][i],up[x][i]));
ret=max(ret,max(Max[y][i]-Minn,Max[x][i]-Minn));
Minn=min(Minn,min(Min[y][i],Min[x][i]));
y=dad[y][i];
x=dad[x][i];
}
}
return ret;
}
int Down(int x,int y)
{
int ret=,Maxn=;
if(dep[x]>dep[y]) swap(x,y);
for(int i=;i>=;--i)
{
if(dep[dad[y][i]]>=dep[x])
{
ret=min(ret,down[y][i]);
ret=min(ret,Maxn-Min[y][i]);
Maxn=max(Maxn,Max[y][i]);
y=dad[y][i];
}
}
if(x==y) return ret;
for(int i=;i>=;--i)
{
if(dad[y][i]!=dad[x][i])
{
ret=min(ret,min(down[y][i],down[x][i]));
ret=min(ret,min(Maxn-Min[y][i],Maxn-Min[x][i]));
Maxn=max(Maxn,max(Max[y][i],Max[x][i]));
y=dad[y][i];
x=dad[x][i];
}
}
return ret;
}
int query_max(int x,int y)
{
if(dep[x]>dep[y]) swap(x,y);
int ret=Pri[y];
for(int i=;i>=;--i)
{
if(dep[dad[y][i]]>=dep[x])
{
ret=max(ret,Max[y][i]);
y=dad[y][i];
}
}
if(x==y) return ret;
for(int i=;i>=;--i)
{
if(dad[y][i]!=dad[x][i])
{
ret=max(ret,Max[x][i]);
ret=max(ret,Max[y][i]);
x=dad[x][i];
y=dad[y][i];
}
}
return ret;
}
int query_min(int x,int y)
{
if(dep[x]>dep[y]) swap(x,y);
int ret=Pri[y];
for(int i=;i>=;--i)
{
if(dep[dad[y][i]]>=dep[x])
{
ret=min(ret,Min[y][i]);
y=dad[y][i];
}
}
if(x==y) return ret;
for(int i=;i>=;--i)
{
if(dad[y][i]!=dad[x][i])
{
ret=min(ret,Min[x][i]);
ret=min(ret,Min[y][i]);
x=dad[x][i];
y=dad[y][i];
}
}
return ret;
}
int main()
{
scanf("%d",&n);
for(int i=;i<=n;++i) scanf("%d",&Pri[i]);
for(int x,y,i=;i<n;++i)
{
scanf("%d%d",&x,&y);
Graph[x].push_back(y);
Graph[y].push_back(x);
}
dfs();
scanf("%d",&m);
for(int x,y;m--;)
{
scanf("%d%d",&x,&y);
if(x==y) {puts("");continue;}
int z=lca(x,y),ans=;
ans=max(ans,Up(x,z));
ans=max(ans,Down(y,z));
ans=max(ans,query_max(x,z)-query_min(y,z));
printf("%d\n",ans);
}
return ;
}

最新文章

  1. 如何修改SharePoint2013服务器场帐号密码
  2. SQL Server Window Function 窗体函数读书笔记二 - A Detailed Look at Window Functions
  3. 驱动中获取PsActiveProcessHead变量地址的五种方法也可以获取KdpDebuggerDataListHead
  4. WrapPanel流布局的一个简单例子
  5. IOS开发备忘
  6. 建立一个ROS msg and srv
  7. ASP.NET 开发者 开始学习ASP.NET Core 2吧
  8. SpringBoot报错:Failed to load ApplicationContext(Mapped Statements collection already contains value)
  9. Python内置函数(39)——locals
  10. ogg 12.3 for sqlserver 2016/2014 CDC模式配置
  11. mongdb 报错“Cannot connect to the MongoDB at 192.179.1.6:27017. Error: Network is unreachable.”
  12. 【转】IAR Embedded Workbench for ARM 8.22.1 基础使用教程
  13. 使用Wscript/cscript调用VB脚本
  14. rabbitmq (三) 发布/订阅
  15. sparking water
  16. week02 课堂作业
  17. kubernetes1.8开启swagger-ui
  18. 驱动程序多线程 PsCreateSystemThread
  19. Ckeditor 中粘贴图片
  20. Android攻城狮学习笔记—入门篇一

热门文章

  1. 关于layer.open() 弹框的使用
  2. mfc为对话框添加启动画面
  3. 20个Flutter实例视频教程-第05节: 酷炫的路由动画-1
  4. 3-3 浮点型字面量 &amp; 3-4浮点型案例
  5. Ubuntu16.04 安装Python3.6 报错
  6. svn图标更新缓慢
  7. python---socket与socketserver
  8. JAVA基础--JAVA API集合框架16
  9. html上传多图并预览
  10. Python 3.x 的一些注意事项