(WWWWWWWWWW)codevs 3305 水果姐逛水果街Ⅱ
写这么长了不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 水果姐逛水果街Ⅱ的更多相关文章
- 水果姐逛水果街Ⅱ codevs 3305
3305 水果姐逛水果街Ⅱ 时间限制: 2 s 空间限制: 256000 KB 题目描述 Description 水果姐第二天心情也很不错,又来逛水果街. 突然,cgh又出现了.cgh施展了魔 ...
- code vs 3305 水果姐逛水果街Ⅱ
3305 水果姐逛水果街Ⅱ 时间限制: 2 s 空间限制: 256000 KB 题目等级 : 钻石 Diamond 题解 题目描述 Description 水果姐第二天心情也很不错, ...
- Codevs 3305 水果姐逛水果街Ⅱ 倍增LCA
题目:http://codevs.cn/problem/3305/ 时间限制: 2 s 空间限制: 256000 KB 题目等级 : 钻石 Diamond 题解 题目描述 Des ...
- CodeVs——T 3305 水果姐逛水果街Ⅱ
http://codevs.cn/problem/3305/ 时间限制: 2 s 空间限制: 256000 KB 题目等级 : 钻石 Diamond 题解 查看运行结果 题目描述 De ...
- codevs 3305 水果姐逛水果街Ⅱ&&codevs3006
题目描述 Description 水果姐第二天心情也很不错,又来逛水果街. 突然,cgh又出现了.cgh施展了魔法,水果街变成了树结构(店与店之间只有一条唯一的路径). 同样还是n家水果店,编号为1~ ...
- Codevs 3304 水果姐逛水果街Ⅰ 线段树
题目: http://codevs.cn/problem/3304/ 时间限制: 2 s 空间限制: 256000 KB 题目等级 : 钻石 Diamond 题解 题目描述 D ...
- CodeVs——T 3304 水果姐逛水果街Ⅰ
http://codevs.cn/problem/3304/ 时间限制: 2 s 空间限制: 256000 KB 题目等级 : 钻石 Diamond 题解 查看运行结果 题目描述 Des ...
- 水果姐逛水果街Ⅰ(codevs 3304)
题目描述 Description 水果姐今天心情不错,来到了水果街. 水果街有n家水果店,呈直线结构,编号为1~n,每家店能买水果也能卖水果,并且同一家店卖与买的价格一样. 学过oi的水果姐迅速发现了 ...
- codevs3305 水果姐逛水果街Ⅱ
本文版权归ljh2000和博客园共有,欢迎转载,但须保留此声明,并给出原文链接,谢谢合作. 本文作者:ljh2000作者博客:http://www.cnblogs.com/ljh2000-jump/转 ...
- codevs3304 水果姐逛水果街
题目描述 Description 水果姐今天心情不错,来到了水果街. 水果街有n家水果店,呈直线结构,编号为1~n,每家店能买水果也能卖水果,并且同一家店卖与买的价格一样. 学过oi的水果姐迅速发现了 ...
随机推荐
- (转)data Table的用法大全
jqyery dataTable 基本用法 一:官方网站:[http://www.datatables.net/] 二:基本使用:[http://www.guoxk.com/node/jquery-d ...
- linux使用curl进行WebService接口测试
参考 :linux使用curl进行接口测试 使用curl 命令模拟POST/GET请求 Linux命令发送Http的get或post请求(curl和wget两种方法) curl 模拟 GET\POST ...
- Eigen::Map
http://cherishlc.iteye.com/blog/2116800 Map类 是 矩阵库Eigen中用来将内存数据 映射为 任意形状的矩阵的类.
- Flutter实战视频-移动电商-56.购物车_商品数量控制区域制作
56.购物车_商品数量控制区域制作 主要做购物车中的数量这里 cart_page文件夹下新建cart_count.dart 减少按钮 因为会有点击事件,所以这里我们使用InkWell. child里面 ...
- 11.ClientCredential模式总结
11.ClientCredential模式总结 服务端定义的Resource叫做api Resource API默认是被保护的 第三方的客户端先去请求 Server拿到access token.带着t ...
- awk用法总结
简介 awk的命名来自于他的三位创始人Alfred Aho .Peter Weinberger 和 Brian Kernighan 的姓氏的首字母. 有多种版本:New awk(nawk),GNU a ...
- CodeForces Gym 100685J Just Another Disney Problem (STL,排序)
题意:给定你大小未知的n个数,你允许有不超过一万次的询问,每次询问两个数,第i个数是否比第j个数小?然后后台会返回给你一个结果YES或者NO(即一行输入), 然后经过多次询问后,你需要给出一个正确的原 ...
- 洛谷 - P4449 - 于神之怒加强版 - 莫比乌斯反演
https://www.luogu.org/problemnew/show/P4449 \(F(n)=\sum\limits_{i=1}^{n}\sum\limits_{i=1}^{m} gcd(i, ...
- ASPNET-ASPNETCORE 认证
话题背景 关于认证我的个人理解是,验证信息的合法性.在我们生活当中,比如门禁,你想进入一个有相对安全措施的小区或者大楼,你需要向保安或者门禁系统提供你的身份信息证明,只有确定你是小区业主,才可以进来, ...
- PJzhang:robots协议的实际场景
猫宁!!! 参考链接: https://bbs.360.cn/thread-15062960-1-1.html https://ziyuan.baidu.com/college/courseinfo? ...