时间限制: 2 s
 空间限制: 256000 KB
 题目等级 : 钻石 Diamond
 
 
 
题目描述 Description

水果姐第二天心情也很不错,又来逛水果街。

突然,cgh又出现了。cgh施展了魔法,水果街变成了树结构(店与店之间只有一条唯一的路径)。

同样还是n家水果店,编号为1~n,每家店能买水果也能卖水果,并且同一家店卖与买的价格一样。

cgh给出m个问题,每个问题要求水果姐从第x家店出发到第y家店,途中只能选一家店买一个水果,然后选一家店(可以是同一家店,但不能往回走)卖出去。求最多可以赚多少钱。

水果姐向学过oi的你求助。

输入描述 Input Description

第一行n,表示有n家店

下来n个正整数,表示每家店一个苹果的价格。

下来n-1行,每行两个整数x,y,表示第x家店和第y家店有一条边。

下来一个整数m,表示下来有m个询问。

下来有m行,每行两个整数x和y,表示从第x家店出发到第y家店。

输出描述 Output Description

有m行。

每行对应一个询问,一个整数,表示面对cgh的每次询问,水果姐最多可以赚到多少钱。

样例输入 Sample Input

10
16 5 1 15 15 1 8 9 9 15 
1 2
1 3
2 4
2 5
2 6
6 7
4 8
1 9
1 10
6
9 1
5 1
1 7
3 3
1 1
3 6

样例输出 Sample Output

7
11
7
0
0
15

数据范围及提示 Data Size & Hint

0<=苹果的价格<=10^8

0<n<=200000

0<m<=10000

思路:lca维护区间差值。

#include<cstdio>
#include<iostream>
#include<vector>
#include<cstring>
using namespace std;
const int N=,pow=,maxx=;
vector<int> g[N];
int d[N],f[N][pow],maxv[N][pow]={},minv[N][pow],diff[N][pow]={},dife[N][pow]={},q[N];
// diff:顺区间最大差
// dife:逆区间最大差
void dfs(int x,int fa)
{
int i,t;
maxv[x][]=max(q[x],q[fa]);
minv[x][]=min(q[x],q[fa]);
diff[x][]=q[x]-q[fa];
dife[x][]=q[fa]-q[x];
d[x]=d[fa]+;
f[x][]=fa;
for(i=;i<pow;i++)
{
f[x][i]=f[f[x][i-]][i-];
maxv[x][i]=max(maxv[x][i-],maxv[f[x][i-]][i-]);
minv[x][i]=min(minv[x][i-],minv[f[x][i-]][i-]);
diff[x][i]=max(maxv[x][i-]-minv[f[x][i-]][i-],max(diff[x][i-],diff[f[x][i-]][i-]));
dife[x][i]=max(maxv[f[x][i-]][i-]-minv[x][i-],max(dife[x][i-],dife[f[x][i-]][i-]));
}
for(i=;i<g[x].size();i++)
if(g[x][i]!=fa)
dfs(g[x][i],x);
}
int lca(int a,int b)
{
int i,t,total=,flag=,maxn=,minn=maxx;
if(d[a]>d[b]){
flag=;
a^=b,b^=a,a^=b;
}
if(d[a]<d[b]){
t=d[b]-d[a];
for(i=;i<pow;i++)
if(t&(<<i)){
if(!flag){
total=max(total,maxn-minv[b][i]);
maxn=max(maxn,maxv[b][i]);
total=max(total,diff[b][i]);
}
else{
total=max(total,maxv[b][i]-minn);
minn=min(minn,minv[b][i]);
total=max(total,dife[b][i]);
}
b=f[b][i];
}
if(!flag) minn=q[a];
else maxn=q[a];
}
else{
if(!flag) minn=q[a],maxn=q[b];
else maxn=q[a],minn=q[b];
}
if(a!=b){
for(i=pow-;i>=;i--)
if(f[a][i]!=f[b][i]){
if(!flag){
total=max(total,maxv[a][i]-minn);
total=max(total,maxn-minv[b][i]);
total=max(total,dife[a][i]);
total=max(total,diff[b][i]);
maxn=max(maxn,maxv[b][i]);
minn=min(minn,minv[a][i]);
}
else{
total=max(total,maxv[b][i]-minn);
total=max(total,maxn-minv[a][i]);
total=max(total,diff[a][i]);
total=max(total,dife[b][i]);
maxn=max(maxn,maxv[a][i]);
minn=min(minn,minv[b][i]);
}
a=f[a][i],b=f[b][i];
}
total=max(total,maxn-minn);
if(!flag){
total=max(total,maxn-q[f[a][]]);
total=max(total,q[f[b][]]-minn);
}
else{
total=max(total,maxn-q[f[b][]]);
total=max(total,q[f[a][]]-minn);
}
}
return total;
}
int main(){
memset(minv,,sizeof(minv));
int n,m,i,j,x,y;
scanf("%d",&n);
for(i=;i<=n;i++)
scanf("%d",&q[i]);
for(i=;i<n;i++){
scanf("%d%d",&x,&y);
g[x].push_back(y);
g[y].push_back(x);
}
for(i=;i<g[].size();i++)
dfs(g[][i],);
scanf("%d",&m);
for(i=;i<=m;i++){
scanf("%d%d",&x,&y);
printf("%d\n",lca(x,y));
}
return ;
}

code vs 3305 水果姐逛水果街Ⅱ的更多相关文章

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

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

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

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

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

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

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

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

  5. codevs3305 水果姐逛水果街Ⅱ

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

  6. codevs3304 水果姐逛水果街

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

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

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

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

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

  9. codevs3304 水果姐逛水果街Ⅰ

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

随机推荐

  1. 使用匿名类型做为ComboBox的DataSource

    使用匿名类型做为ComboBox的DataSource   ArrayList list = new ArrayList();            list.Add(new { id = " ...

  2. CodeForces - 749C Voting

    C. Voting time limit per test 1 second memory limit per test 256 megabytes input standard input outp ...

  3. [APIO2008]DNA

    https://zybuluo.com/ysner/note/1158123 题面 戳我 解析 我们要求出第\(r\)种方案,莫过于看其前面什么时候有\(r-1\)种方案. 于是,我们要求出每种情况的 ...

  4. Python 33(2)进程理论

    一:什么是进程         进程指的是一个正在进行 / 运行的程序,进程是用来描述程序执行过程的虚拟概念 进程vs程序 程序:一堆代码 进程:程序的执行的过程 进程的概念起源于操作系统,进程是操作 ...

  5. 关于sklearn中的导包交叉验证问题

    机器学习sklearn中的检查验证模块: 原版本导包: from sklearn.cross_validation import cross_val_score 导包报错: 模块继承在cross_va ...

  6. 汇编程序10:计算长度为C字节的数据和

    assume cs:code code segment mov ax,0ffffh //起始段地址 mov ds,ax mov bx,0 //偏移变量 mov dx,0 //保存结果 mov cx,1 ...

  7. lua 10进制转换成其它进制table表示

    -- params@num integer -- ~) 默认为10 -- NOTE:先不输出符号 function NumberToArray(num, radix) if type(num) ~= ...

  8. P3709 大爷的字符串题(50分)

    题目背景 在那遥远的西南有一所学校 /*被和谐部分*/ 然后去参加该省省选虐场 然后某蒟蒻不会做,所以也出了一个字符串题: 题目描述 给你一个字符串a,每次询问一段区间的贡献 贡献定义: 每次从这个区 ...

  9. 扩展银行项目,添加一个(客户类)Customer类。Customer类将包含一个Account对象。

    练习目标-使用引用类型的成员变量:在本练习中,将扩展银行项目,添加一个(客户类)Customer类.Customer类将包含一个Account对象. 任务 在banking包下的创建Customer类 ...

  10. crontab与系统时间不一致

    将线上数据库迁移至虚拟机后,运维没有把时间修改. 在后期把时间修改完成后,在数据库上也要修改修改,但是定时任务的备份时间却不在凌晨4点执行,而是在中午12:10分执行. 原因是修改时间后,需要重启cr ...