传送门

题意:

  某村庄有n个小屋,n-1条道路连接着n个小屋(无环),求村庄A到村庄B的距离,要求是经过任一村庄不超过一次。

题解:

  求出 lca = LCA(u,v) , 然后答案便是dist[u] + dist[v] - 2 * dist[lca];

AC代码:

 #include<iostream>
#include<vector>
#include<cstdio>
#include<cmath>
#include<cstring>
using namespace std;
#define pb(x) push_back(x)
#define mem(a,b) memset(a,b,sizeof(a))
const int maxn=4e4+; int n,q;
int dist[maxn];//dist[i]: 节点i与节点1的距离,假定1为根节点
int vs[*maxn];//欧拉序列
int depth[*maxn];//深度序列
int pos[maxn];//pos[i]:节点i在欧拉序列中第一次出现的位置
bool vis[maxn];
struct Edge
{
int to;
int w;
Edge(int a=,int b=):to(a),w(b){}
};
vector<Edge >G[maxn];
void addEdge(int u,int v,int w)
{
G[u].pb(Edge(v,w));
}
struct RMQ
{
int dp[][*maxn];
void rmq()
{
int tot=*n-;
for(int i=;i <= tot;++i)
dp[][i]=i;
for(int k=;(<<k) <= tot;++k)
for(int i=;((<<k)+i-) <= tot;++i)
if(depth[dp[k-][i]] > depth[dp[k-][i+(<<(k-))]])
dp[k][i]=dp[k-][i+(<<(k-))];
else
dp[k][i]=dp[k-][i];
}
int lca(int u,int v)
{
u=pos[u],v=pos[v];
if(u > v)
swap(u,v);
int k=log(v-u+)/log();
return vs[min(dp[k][u],dp[k][v-(<<k)+])];
}
}_rmq;
void Dfs(int u,int dis,int dep,int &k)
{
vs[++k]=u;
depth[k]=dep;
pos[u]=k;
dist[u]=dis;
vis[u]=true;
for(int i=;i < G[u].size();++i)
{
int to=G[u][i].to;
int w=G[u][i].w;
if(!vis[to])
{
Dfs(to,dis+w,dep+,k);
vs[++k]=u;
depth[k]=dep;
}
}
}
void LCA()
{
int k=;
Dfs(,,,k);
_rmq.rmq();
}
void Init()
{
mem(vis,false);
for(int i=;i <= n;++i)
G[i].clear();
}
int main()
{
// freopen("C:/Users/hyacinthLJP/Desktop/stdin/hdu2586.txt","r",stdin);
int t;
scanf("%d",&t);
while(t--)
{
Init();
scanf("%d%d",&n,&q);
for(int i=;i < n;++i)
{
int u,v,w;
scanf("%d%d%d",&u,&v,&w);
addEdge(u,v,w);
addEdge(v,u,w);
}
LCA();
for(int i=;i <= q;++i)
{
int u,v;
scanf("%d%d",&u,&v);
int lca=_rmq.lca(u,v);
printf("%d\n",dist[u]+dist[v]-*dist[lca]);
}
}
return ;
}

基于RMQ的LCA

hdu 2586(裸LCA)的更多相关文章

  1. How far away ? HDU - 2586 【LCA】【RMQ】【java】

    题目大意:求树上任意两点距离. 思路: dis[i]表示i到根的距离(手动选根),则u.v的距离=dis[u]+dis[v]-2*dis[lca(u,v)]. lca:u~v的dfs序列区间里,深度最 ...

  2. hdu 2874(裸LCA)

    传送门:Problem 2874 https://www.cnblogs.com/violet-acmer/p/9686774.html 改了一晚上bug,悲伤辣么大,明天再补详细题解 题解: 题目中 ...

  3. 【HDU 2586】LCA模板

    在一棵树上 求2个点的最短距离.那么首先利用LCA找到2个点的近期公共祖先 公式:ans = dis(x) + dis(y) - 2 * dis(lca(x,y)) 这里的dis(x)指的上x距离根节 ...

  4. HDU 2586(LCA欧拉序和st表)

    什么是欧拉序,可以去这个大佬的博客(https://www.cnblogs.com/stxy-ferryman/p/7741970.html)巨详细 因为欧拉序中的两点之间,就是两点遍历的过程,所以只 ...

  5. HDU - 2586 How far away ?(LCA模板题)

    HDU - 2586 How far away ? Time Limit: 1000MS   Memory Limit: 32768KB   64bit IO Format: %I64d & ...

  6. hdu 2586 How far away ?倍增LCA

    hdu 2586 How far away ?倍增LCA 题目链接 http://acm.hdu.edu.cn/showproblem.php?pid=2586 思路: 针对询问次数多的时候,采取倍增 ...

  7. LCA(最近公共祖先)--tarjan离线算法 hdu 2586

    HDU 2586 How far away ? Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/ ...

  8. HDU 2586 (LCA模板题)

    题目链接: http://acm.hdu.edu.cn/showproblem.php?pid=2586 题目大意:在一个无向树上,求一条链权和. 解题思路: 0 | 1 /   \ 2      3 ...

  9. HDU 2586 How far away ? (LCA)

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=2586 LCA模版题. RMQ+LCA: #include <iostream> #incl ...

随机推荐

  1. NTP系统时间同步-操作记录

    在初始化一台linux服务器后,发现这台服务器的时间不对[root@dev ~]# date2016年 10月 11日 星期二 07:04:34 CST Linux时钟分为系统时钟 (System C ...

  2. rrd文件及rrd文件与实际数据的对比研究。

    一,什么是rrd文件? 所 谓的“Round Robin” 其实是一种存储数据的方式,使用固定大小的空间来存储数据,并有一个指针指向最新的数据的位置.我们可以把用于存储数据的数据库的空间看成一个圆,上 ...

  3. javaScript常用API合集

    节点 1.1 节点属性 Node.nodeName   //返回节点名称,只读 Node.nodeType   //返回节点类型的常数值,只读 Node.nodeValue  //返回Text或Com ...

  4. B. Vova and Trophies

    链接 [https://codeforces.com/contest/1082/problem/B] 题意 给你一个包含GS的字符串,只允许交换一次任意不同位置的字符,问最长的连续G串是多少 分析 很 ...

  5. 作业七:Linux内核如何装载和启动一个可执行程序

    作业七:Linux内核如何装载和启动一个可执行程序 一.编译链接的过程和ELF可执行文件格式 可执行文件的创建——预处理.编译和链接 在object文件中有三种主要的类型. 一个可重定位(reloca ...

  6. 第三个Sprint冲刺第八天(燃尽图)

  7. python 生成器、列表解析式、yield、迭代器

    开局一张图总结关系 一.列表解析式 我们习惯生成列表通过list = [1, 2, 3]的方式.还有一种很方便的列表生成方式 list = [a*2 for a in range(10)],或者lis ...

  8. ngnix使用超时响应时间配置避坑一例

    ngnix的超时响应时间配置得比tomcat的spring mvc响应时间还小,悲剧就发生了,生产环境还不易发现. 就好比定制固定木柜没考虑进门的尺寸,横竖斜都进不去,太悲剧了.哈哈哈,以此为鉴!~

  9. OSI的七层模型介绍

    应用层: 文件传输,电子邮件,文件服务,虚拟终端 TFTP,HTTP,SNMP,FTP,SMTP,DNS,Telnet 表示层: 数据格式化,代码转换,数据加密 没有协议. (信息的语法语义以及它们的 ...

  10. webstrom 安装Babel

    https://www.jianshu.com/p/b9bd2ec9ec80 https://www.cnblogs.com/zhishaofei/p/6061568.html https://blo ...