POJ 1986 Distance Queries LCA两点距离树
标题来源:POJ 1986 Distance Queries
意甲冠军:给你一棵树 q第二次查询 每次你问两个点之间的距离
思路:对于2点 u v dis(u,v) = dis(root,u) + dis(root,v) - 2*dis(roor,LCA(u,v)) 求近期公共祖先和dis数组
#include <cstdio>
#include <cstring>
#include <vector>
using namespace std;
const int maxn = 40010;
int first[maxn], head[maxn], cnt, sum;
struct edge
{
int u, v, w, next;
}e[maxn*2], qe[maxn], Q[maxn];
int ans[maxn];
int f[maxn], vis[maxn];
int d[maxn];
void AddEdge(int u, int v, int w)
{
e[cnt].u = u;
e[cnt].v = v;
e[cnt].w = w;
e[cnt].next = first[u];
first[u] = cnt++;
e[cnt].u = v;
e[cnt].v = u;
e[cnt].w = w;
e[cnt].next = first[v];
first[v] = cnt++;
} void AddEdge2(int u, int v, int w)
{
qe[sum].u = u;
qe[sum].v = v;
qe[sum].w = w;
qe[sum].next = head[u];
head[u] = sum++;
qe[sum].u = v;
qe[sum].v = u;
qe[sum].w = w;
qe[sum].next = head[v];
head[v] = sum++;
} int find(int x)
{
if(f[x] != x)
return f[x] = find(f[x]);
return f[x];
}
void LCA(int u, int k)
{
f[u] = u;
d[u] = k;
vis[u] = true;
for(int i = first[u]; i != -1; i = e[i].next)
{
int v = e[i].v;
if(vis[v])
continue;
LCA(v, k + e[i].w);
f[v] = u;
}
for(int i = head[u]; i != -1; i = qe[i].next)
{
int v = qe[i].v;
if(vis[v])
{
ans[qe[i].w] = find(v);
}
}
}
int main()
{
int n, m;
memset(first, -1, sizeof(first));
memset(head, -1, sizeof(head));
cnt = 0;
sum = 0;
scanf("%d %d", &n, &m);
for(int i = 0; i < m; i++)
{
int u, v, w;
char s[10];
scanf("%d %d %d %s", &u, &v, &w, s);
AddEdge(u, v, w);
}
int q;
scanf("%d", &q);
for(int i = 0; i < q; i++)
{
int u, v;
scanf("%d %d", &u, &v);
Q[i].u = u, Q[i].v = v;
AddEdge2(u, v, i);
AddEdge2(v, u, i); }
memset(vis, 0, sizeof(vis));
d[1] = 0;
LCA(1, 0);
for(int i = 0; i < q; i++)
{
int u = Q[i].u, v = Q[i].v;
printf("%d\n", d[u] + d[v] - 2*d[ans[i]]);
}
return 0;
}
版权声明:本文博客原创文章。博客,未经同意,不得转载。
POJ 1986 Distance Queries LCA两点距离树的更多相关文章
- POJ.1986 Distance Queries ( LCA 倍增 )
POJ.1986 Distance Queries ( LCA 倍增 ) 题意分析 给出一个N个点,M条边的信息(u,v,w),表示树上u-v有一条边,边权为w,接下来有k个询问,每个询问为(a,b) ...
- POJ 1986 - Distance Queries - [LCA模板题][Tarjan-LCA算法]
题目链接:http://poj.org/problem?id=1986 Description Farmer John's cows refused to run in his marathon si ...
- poj 1986 Distance Queries LCA
题目链接:http://poj.org/problem?id=1986 Farmer John's cows refused to run in his marathon since he chose ...
- POJ 1986 Distance Queries(LCA Tarjan法)
Distance Queries [题目链接]Distance Queries [题目类型]LCA Tarjan法 &题意: 输入n和m,表示n个点m条边,下面m行是边的信息,两端点和权,后面 ...
- POJ 1986 Distance Queries / UESTC 256 Distance Queries / CJOJ 1129 【USACO】距离咨询(最近公共祖先)
POJ 1986 Distance Queries / UESTC 256 Distance Queries / CJOJ 1129 [USACO]距离咨询(最近公共祖先) Description F ...
- POJ 1986 Distance Queries 【输入YY && LCA(Tarjan离线)】
任意门:http://poj.org/problem?id=1986 Distance Queries Time Limit: 2000MS Memory Limit: 30000K Total ...
- POJ 1986 Distance Queries(Tarjan离线法求LCA)
Distance Queries Time Limit: 2000MS Memory Limit: 30000K Total Submissions: 12846 Accepted: 4552 ...
- poj 1986 Distance Queries(LCA)
Description Farmer John's cows refused to run in his marathon since he chose a path much too long fo ...
- poj 1986 Distance Queries(LCA:倍增/离线)
计算树上的路径长度.input要去查poj 1984. 任意建一棵树,利用树形结构,将问题转化为u,v,lca(u,v)三个点到根的距离.输出d[u]+d[v]-2*d[lca(u,v)]. 倍增求解 ...
随机推荐
- 【心情】Priority_queue容器的用法
所给的代码最顶端是最小的元素 要改为最顶端是最大的则只需把 friend bool operator<(Node a, Node b) { return a.val > b.val; } ...
- struts2-token防止重复提交解决办法
1.配置struts.xml全局防重复提交拦截器栈: <struts> <package name="module" extends="struts-d ...
- C++实现简单的内存块自己主动管理
#ifndef __MEM__H #define __MEM__H #include<iostream> using namespace std; //自己主动管理内存块 typedef ...
- java pns
http://autumnrain-zgq.iteye.com/blog/1743279 http://blog.csdn.net/a351945755/article/details/2218939 ...
- [Postgres] Group and Aggregate Data in Postgres
How can we see a histogram of movies on IMDB with a particular rating? Or how much movies grossed at ...
- 手机端自适应布局demo
原型如下: 要求如下:适应各种机型 源码如下: <!DOCTYPE html > <html> <head> <meta http-e ...
- hdu 4059 The Boss on Mars
The Boss on Mars Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others) ...
- 简单sql部分强化练习题
简单查询部分sql练习题 -- 选择部门30中的全部职工 select * from emp where deptno = 30; -- 列出全部业务员(CLERK)的姓名,编号,和部门编号 sele ...
- java命名规则(转)
1. JAVA源文件的命名 JAVA源文件名必须和源文件中所定义的类的类名相同. 2. Package的命名 Package名的第一部分应是小写ASCII字符,并且是顶级域名之一,通常是com.edu ...
- CentOS 配置epel源
先查询下有没有epel rpm -qa|grep epel 没有的话到官网https://fedoraproject.org/wiki/EPEL下载rpm包 然后 rpm -ivh 安装 安装完毕后到 ...