写这么长了不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 ;
}

(WWWWWWWWWW)codevs 3305 水果姐逛水果街Ⅱ的更多相关文章

  1. 水果姐逛水果街Ⅱ codevs 3305

    3305 水果姐逛水果街Ⅱ  时间限制: 2 s  空间限制: 256000 KB   题目描述 Description 水果姐第二天心情也很不错,又来逛水果街. 突然,cgh又出现了.cgh施展了魔 ...

  2. code vs 3305 水果姐逛水果街Ⅱ

    3305 水果姐逛水果街Ⅱ  时间限制: 2 s  空间限制: 256000 KB  题目等级 : 钻石 Diamond 题解       题目描述 Description 水果姐第二天心情也很不错, ...

  3. Codevs 3305 水果姐逛水果街Ⅱ 倍增LCA

    题目:http://codevs.cn/problem/3305/  时间限制: 2 s   空间限制: 256000 KB   题目等级 : 钻石 Diamond 题解       题目描述 Des ...

  4. CodeVs——T 3305 水果姐逛水果街Ⅱ

    http://codevs.cn/problem/3305/  时间限制: 2 s  空间限制: 256000 KB  题目等级 : 钻石 Diamond 题解  查看运行结果     题目描述 De ...

  5. codevs 3305 水果姐逛水果街Ⅱ&&codevs3006

    题目描述 Description 水果姐第二天心情也很不错,又来逛水果街. 突然,cgh又出现了.cgh施展了魔法,水果街变成了树结构(店与店之间只有一条唯一的路径). 同样还是n家水果店,编号为1~ ...

  6. Codevs 3304 水果姐逛水果街Ⅰ 线段树

    题目: http://codevs.cn/problem/3304/   时间限制: 2 s   空间限制: 256000 KB   题目等级 : 钻石 Diamond 题解       题目描述 D ...

  7. CodeVs——T 3304 水果姐逛水果街Ⅰ

    http://codevs.cn/problem/3304/ 时间限制: 2 s  空间限制: 256000 KB  题目等级 : 钻石 Diamond 题解  查看运行结果     题目描述 Des ...

  8. 水果姐逛水果街Ⅰ(codevs 3304)

    题目描述 Description 水果姐今天心情不错,来到了水果街. 水果街有n家水果店,呈直线结构,编号为1~n,每家店能买水果也能卖水果,并且同一家店卖与买的价格一样. 学过oi的水果姐迅速发现了 ...

  9. codevs3305 水果姐逛水果街Ⅱ

    本文版权归ljh2000和博客园共有,欢迎转载,但须保留此声明,并给出原文链接,谢谢合作. 本文作者:ljh2000作者博客:http://www.cnblogs.com/ljh2000-jump/转 ...

  10. codevs3304 水果姐逛水果街

    题目描述 Description 水果姐今天心情不错,来到了水果街. 水果街有n家水果店,呈直线结构,编号为1~n,每家店能买水果也能卖水果,并且同一家店卖与买的价格一样. 学过oi的水果姐迅速发现了 ...

随机推荐

  1. springMVC拦截配置

    1.web.xml文件配置 <!-- spring mvc --> <servlet> <servlet-name>DispatcherServlet</se ...

  2. DNS与BIND介绍

    前言 DNS(Domain Name System),网域名称系统,是互联网上基础性的服务.DNS 将域名和网络服务器的 IP 地址相互映射,并将这些数据保存至 DNS 服务器.两台主机通信事实上是依 ...

  3. CSS3 制作魔方 - 相关立体样式

    最好的实践,就是给定一个实践的目标去实践. 目标:利用 CSS3 的一些特性,绘制一个魔方,要可以玩转的那种,即上下左右每一层都可以独立旋转.效果如下: 为了完成此效果,将使用到以下相关概念和样式:坐 ...

  4. QRegExp解析

    正则表达式(regular expression)就是用一个“字符串”来描述一个特征,然后去验证另一个“字符串”是否符合这个特征.比如 表达式“ab+” 描述的特征是“一个 'a' 和 任意个 'b' ...

  5. lightoj1047 【简单线性DP】

    因为写不出hdu3401...好像要用单调队列优化...这边水了一个... 题意: 给n个房子涂色,给出n个房子对应颜色的花费,问涂完所有颜色花费最少. 保证相邻房子颜色不能相同. 思路: dp[i] ...

  6. AttributedString 图片间距问题

    1.NSMutableAttributedString如何显示图片 NSMutableAttributedString *vipStr = [[NSMutableAttributedString al ...

  7. 快速对接payjs的个人支付接口(收银台模式)

    近期在了解个人支付接口,希望能解决我在微信上支付的问题.找了很多平台对比再三,感觉payjs比较专业,其它多是模仿payjs的东西.同时支持支付宝和微信,由于本人支付宝还没开通(需要有一定流量才给开通 ...

  8. Cordova/Cordova.h file not found的解决方法

    参考http://stackoverflow.com/questions/10714600/cdvplugin-h-file-not-found-in-cordova-as-component-cle ...

  9. luoguP2408不同子串个数

    传送门 可以知道每一个子串都是后缀的前缀,那么对于第\(i\)小的后缀的贡献就可以表示为n-sa[i]+1 然而会存在重复的子串,注意height数组的定义,对于sa[i-1]和sa[i],只有hei ...

  10. win10子系统linux编译ffmpeg

    android-ndk-r14b(linux版) ffmpeg-4.0 开启win10子系统(控制面板->程序和功能->启用或关闭Windows功能 然后在 适用与 Linux 的 Win ...