题目:https://codeforc.es/gym/101810/problem/M

题意:给 你一颗树,下面有m次查询,求u->v的最大值是多少,输入两点之间都会有两条边,正边有正权,反边有反权,然后问u->v可以经过的最大权值是多少

思路:我们首先以u为根我们会发现我们走非v所在子树时我们都可以把所有边走完并且回来,对于v所在子树我们也可以把正反两条边都走完,u-v的最短的那条路只能走一遍,所以这个问题就转化为了求最长链问题,u->v的最长链,但是我们有m次查询,我们不可能每次取遍历所有的点来找最长链,我们其实可以以1为根,然后用两个数组分别记录 当前点到根的距离的正反权,然后自己画图能够看出两点的距离其实就是   dis1[u]-dis1[lca(u,v)]  +  dis2[v]-dis2[lca(u,v)]

#include<bits/stdc++.h>
using namespace std;
#define mst(ss,b) memset((ss),(b),sizeof(ss))
const int N = 1e5+;
int t,n,m,dis[N],dis1[N],fa[N][],fa1[N][],dep[N],dep1[N],vs[N],vs1[N];
struct nd{
int to,w,w1;
};
vector<nd> g[N]; void init() {
for(int i=;i<=n;i++) g[i].clear();
mst(dis,),mst(fa,),mst(dep,),mst(vs,);
mst(dis1,),mst(fa1,),mst(dep1,),mst(vs1,);
} void dfs(int x) {///求出每个节点到根节点的距离、深度、父亲
vs[x]=;
for(int i=;i<g[x].size();i++) {
nd tp=g[x][i];
int v=tp.to,w=tp.w,w1=tp.w1;
if(vs[v]) continue;
fa[v][]=x;
fa1[v][]=x;
dis[v]=dis[x]+w;
dis1[v]=dis1[x]+w1;
dep[v]=dep[x]+;
dep1[v]=dep1[x]+;
dfs(v);
}
} void bz() {///倍增预处理
for(int j=;j<;j++)///fa[i][j]表示结点 i 的第2^j个祖先
for(int i=;i<=n;i++)
fa[i][j]=fa[fa[i][j-]][j-],
fa1[i][j]=fa1[fa1[i][j-]][j-];
} int lca(int u,int v) {
if(dep[u]<dep[v]) swap(u,v);///注意是交换u和v,不是交换dep[u]和dep[v]
int d=dep[u]-dep[v];
for(int i=;i<;i++)///先调整到同一深度
if(d&(<<i)) u=fa[u][i];
if(u==v) return u;
for(int i=;i>=;i--) {///注意是倒着for,二进制拆分,从大到小尝试
if(fa[u][i]!=fa[v][i]) {
u=fa[u][i];
v=fa[v][i];
}
}
return fa[u][];
} int main() {
while(~scanf("%d",&t)) {
while(t--) {
scanf("%d",&n);
init();
long long ans = ;
for(int i=;i<n;i++) {
int a,b,c,d;
scanf("%d%d%d%d",&a,&b,&c,&d);
g[a].push_back({b,c,d});
g[b].push_back({a,d,c});
ans += c+d;
}
dep[]=,dis[]=;
dep1[]=,dis1[]=;
dfs();
bz();
scanf("%d",&m);
for(int i=;i<=m;i++) {
int u,v;
scanf("%d%d",&u,&v);
printf("%lld\n",ans-(dis1[v]-dis1[lca(u,v)]+dis[u]-dis[lca(u,v)]));
}
}
}
return ;
}

gym 101810 M. Greedy Pirate (LCA)的更多相关文章

  1. GYM101810 ACM International Collegiate Programming Contest, Amman Collegiate Programming Contest (2018) M. Greedy Pirate (LCA)

    题意:有\(n\)个点,\(n-1\)条边,每条边正向和反向有两个权值,且每条边最多只能走两次,有\(m\)次询问,问你从\(u\)走到\(v\)的最大权值是多少. 题解:可以先在纸上画一画,不难发现 ...

  2. codeforces gym #101161E - ACM Tax(lca+主席树)

    题目链接: http://codeforces.com/gym/101161/attachments 题意: 给出节点数为$n$的树 有$q$次询问,输出$a$节点到$b$节点路程中,经过的边的中位数 ...

  3. Codeforces Gym 100015C City Driving 离线LCA

    City Driving 题目连接: http://codeforces.com/gym/100015/attachments Description You recently started fre ...

  4. Gym 101810

    友情提示: 这篇题解并没有GJKL,因为我也不会,而且看别人代码也看不懂,而且问学长还不给我讲!hmc:这个题巨麻烦,我只能说balabala.我不学了我退役了啊! A:这傻逼题我从开头wa了四个小时 ...

  5. gym 101889I Imperial roads 最小生成树+LCA

    题目传送门 题意: 给出一幅无向带权图,q次询问,每次询问都求一棵包含给出的边的最小生成树. 思路: 首先求出最小生成树(kruskal),如果查询的边在最小生成树上,肯定是直接输出最小生成树,如果不 ...

  6. Gym - 101810H ACM International Collegiate Programming Contest (2018)

    bryce1010模板 http://codeforces.com/gym/101810 #include <bits/stdc++.h> using namespace std; #de ...

  7. Gym - 101810F ACM International Collegiate Programming Contest (2018)

    bryce1010模板 http://codeforces.com/gym/101810 #include<bits/stdc++.h> using namespace std; #def ...

  8. Gym - 101810E ACM International Collegiate Programming Contest (2018)

    bryce1010模板 http://codeforces.com/gym/101810 #include<bits/stdc++.h> using namespace std; #def ...

  9. Gym - 101810D ACM International Collegiate Programming Contest (2018)

    bryce1010模板 http://codeforces.com/gym/101810 #include <bits/stdc++.h> using namespace std; #de ...

随机推荐

  1. Eclipse总是自动跳到ThreadPoolExecutor

    出现这种状况是因为Eclipse默认开启挂起未捕获的异常(Suspend execution on uncaught exceptions),只要关闭此项就可以了.解决方法:在eclipse中选择Wi ...

  2. 将多个jpg文件以追加形式合并成一个文件_delphi教程 bmp 合并 http://www.west.cn/www/info/58058-1.htm

    将多个jpg文件以追加形式合并成一个文件_delphi教程 作者:网友供稿 点击:0 西部数码-全国虚拟主机10强!20余项虚拟主机管理功能,全国领先!第6代双线路虚拟主机,南北访问畅通无阻!云服务器 ...

  3. 校内模拟赛 : Rima —— 字典树+树形DP

    首先说一下,对一个刚学Trie树的蒟蒻来说(就是我),这道题是一道好题.Trie树比较简单,所以就不详细写了. Rima 内存限制:256 MiB 时间限制:1000 ms 标准输入输出 题目类型:传 ...

  4. Scala函数高级操作

    字符串高级操作:***** 非常重要 将函数赋值给变量/值def sayHello(name:String): Unit = { println(s"Hello:$name")} ...

  5. 深入理解DiscoveryClient

    Spring Cloud Commons 提供的抽象 最早的时候服务发现注册都是通过DiscoveryClient来实现的,随着版本变迁把DiscoveryClient服务注册抽离出来变成了Servi ...

  6. 最小公倍数(lcm与gcd)

    J - Worker Avin meets a rich customer today. He will earn 1 million dollars if he can solve a hard p ...

  7. AC自动机题单

    AC自动机题目 真的超级感谢xzy 真的帮到我很多 题单 [X] [luogu3808][模板]AC自动机(简单版) https://www.luogu.org/problemnew/show/P38 ...

  8. Leetcode Lect3 时间复杂度/空间复杂度

    时间复杂度 复杂度 可能对应的算法 备注 O(1) 位运算 常数级复杂度,一般面试中不会有 O(logn) 二分法,倍增法,快速幂算法,辗转相除法   O(n) 枚举法,双指针算法,单调栈算法,KMP ...

  9. IIS 应用池资源定时回收

    方法1: 方法2:

  10. NGUI的button的创建的问题(Button Script)

    一,我们可以给了label,sprite等添加button事件 我们先添加一个label在UI_Root上,然后选中该label,右键-Attach-Box Collider,添加,当你添加完了Box ...