HDU 2586 (LCA模板题)
题目链接: http://acm.hdu.edu.cn/showproblem.php?pid=2586
题目大意:在一个无向树上,求一条链权和。
解题思路:
0
|
1
/ \
2 3
设dist[i]为i到根0的链和,求法(Dfs过程中dist[v]=dist[u]+e[i].w)
对于树中任意两点形成的链,可以通过LCA最近公共祖先剖分。
比如2->3,就可以经过LCA点1: 2->1->3
链和=dist[u]+dist[v]-2*dist[LCA[u,v]]
(0-1-2)+(0-1-3)-2*(0-1)=(2-1-3),有点容斥原理的味道。
LCA比较快的是Tarjan离线法,把全部query也做成一个无向树,离线处理。
过程分为两个stage,stage 1对连接树处理,stage 2对query树处理。
两个stage可以颠倒。正写法 倒写法。在Tarjan(u)中,并查集find(v),可以获得LCA。
LCA存储比较头疼,由于LCA是双向共享的。可以建个ancestor数组,索引是查询序号。
也可以直接存在query树的链式前向星中。
本题双向建一个无向树,任意选择一个起点作为root做LCA都可以。
- #include "cstdio"
- #include "cstring"
- #define maxn 40005
- #define maxm 205
- int head[maxn],qhead[maxn],dist[maxn],tot1,tot2,f[maxn],vis[maxn],ancestor[maxn];
- struct Edge
- {
- int to,next,w;
- }e[maxn*];
- struct Query
- {
- int from,to,next,idx;
- }q[maxn*];
- void addedge(int u,int v,int w)
- {
- e[tot1].to=v;
- e[tot1].w=w;
- e[tot1].next=head[u];
- head[u]=tot1++;
- }
- void addquery(int u,int v,int idx)
- {
- q[tot2].from=u;
- q[tot2].to=v;
- q[tot2].next=qhead[u];
- q[tot2].idx=idx;
- qhead[u]=tot2++;
- }
- int find(int x) {return x!=f[x]?f[x]=find(f[x]):x;}
- void Union(int u,int v)
- {
- u=find(u),v=find(v);
- if(u!=v) f[v]=u;
- }
- void LCA(int u)
- {
- vis[u]=true;
- f[u]=u;
- for(int i=head[u];i!=-;i=e[i].next)
- {
- int v=e[i].to,w=e[i].w;
- if(!vis[v])
- {
- dist[v]=dist[u]+w;
- LCA(v);
- Union(u,v);
- }
- }
- for(int i=qhead[u];i!=-;i=q[i].next)
- {
- int v=q[i].to;
- if(vis[v]) ancestor[q[i].idx]=find(v);
- //or storage e[i].lca=e[i^1].lca=find(v)
- }
- }
- int main()
- {
- //freopen("in.txt","r",stdin);
- int T,n,m,u,v,c;
- scanf("%d",&T);
- while(T--)
- {
- tot1=tot2=;
- memset(head,-,sizeof(head));
- memset(qhead,-,sizeof(qhead));
- memset(vis,,sizeof(vis));
- dist[]=;
- scanf("%d%d",&n,&m);
- for(int i=;i<n-;i++)
- {
- scanf("%d%d%d",&u,&v,&c);
- addedge(u,v,c);
- addedge(v,u,c);
- }
- for(int i=;i<m;i++)
- {
- scanf("%d%d",&u,&v);
- addquery(u,v,i);
- addquery(v,u,i);
- }
- LCA();
- for(int i=;i<tot2;i=i+)
- {
- int u=q[i].from,v=q[i].to,idx=q[i].idx;
- printf("%d\n",dist[u]+dist[v]-*dist[ancestor[idx]]);
- }
- }
- }
HDU 2586 (LCA模板题)的更多相关文章
- [hdu 2586]lca模板题(在线+离线两种版本)
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=2586 在线版本: 在线方法的思路很简单,就是倍增.一遍dfs得到每个节点的父亲,以及每个点的深度.然后 ...
- hdu - 2586 (LCA板子题)
传送门 (这次的英文题面要比上一个容易看多了) (英语蒟蒻的卑微) 又是一个很裸的LCA题 (显然,这次不太容易打暴力咧) (但听说还是有大佬用dfs直接a掉了) 正好 趁这个机会复习一下LCA 这里 ...
- hdu 2586 How far away?(LCA模板题+离线tarjan算法)
How far away ? Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others)To ...
- HDU - 2586 How far away ?(LCA模板题)
HDU - 2586 How far away ? Time Limit: 1000MS Memory Limit: 32768KB 64bit IO Format: %I64d & ...
- HDU 2586——How far away ?——————【LCA模板题】
How far away ? Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others)To ...
- HDU 2138 Miller-Rabin 模板题
求素数个数. /** @Date : 2017-09-18 23:05:15 * @FileName: HDU 2138 miller-rabin 模板.cpp * @Platform: Window ...
- HDU 2586 How far away ?【LCA模板题】
传送门:http://acm.hdu.edu.cn/showproblem.php?pid=2586 题意:给你N个点,M次询问.1~N-1行输入点与点之间的权值,之后M行输入两个点(a,b)之间的最 ...
- HDU 2586 How far away ? 离线lca模板题
How far away ? Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others)To ...
- HDU 2586 ( LCA/tarjan算法模板)
链接:http://acm.hdu.edu.cn/showproblem.php?pid=2586 题意:n个村庄构成一棵无根树,q次询问,求任意两个村庄之间的最短距离 思路:求出两个村庄的LCA,d ...
随机推荐
- Delphi中的接口和抽象类
参考:http://blog.csdn.net/xinzheng_wang/article/details/6058643 接口:Interface Delphi中接口中的关键字Interface,但 ...
- Linux Shell 高级编程技巧2----shell工具
2.shell工具 2.1.日志文件 简介 创建日志文件是很重要的,记录了重要的信息.一旦出现错误,这些信息对于我们排错是非常有用的:监控的信息也可以记录到日 ...
- Linux环境下段错误的产生原因及调试方法小结
转载自http://www.cnblogs.com/panfeng412/archive/2011/11/06/2237857.html 最近在Linux环境下做C语言项目,由于是在一个原有项目基础之 ...
- 小鼠迷宫问题【sdut1157】【dfs,bfs综合题目】
小鼠迷宫问题 Time Limit: 1500ms Memory limit: 65536K 有疑问?点这里^_^ 题目描述 小鼠a与小鼠b身处一个m×n的迷宫中,如图所示.每一个方格表示迷宫中 ...
- Counterfeit Dollar -----判断12枚钱币中的一个假币
Counterfeit Dollar Time Limit:1000MS Memory Limit:10000KB 64bit IO Format:%I64d & %I64u ...
- Microsoft SQL Server 博客目录
基础概念篇 SQL Server排序规则 SQL SERVER 统计信息概述(Statistics) SQL SERVER 索引之聚集索引和非聚集索引的描述 Sql Server 索引之唯一索引和筛选 ...
- 【leetcode】Reverse Integer
题目描述: Reverse digits of an integer. Example1: x = 123, return 321Example2: x = -123, return -321 很简单 ...
- 配置ogg异构oracle-mysql(2)源端配置
源端配置大致分为如下三个步骤:配置mgr,配置抽取进程,配置投递进程 在源端先创建一张表,记得带主键: SQL> create table ah4(id int ,name varchar(10 ...
- Dwz下拉菜单的二级联动
在DWZ文档中对组合框combox的是这样描述的: 在传统的select 用class 定义:class=”combox”, html 扩展:保留原有属性name, 增加了属性:ref. ref 属 ...
- 利用Visual GDB在Visual Studio中进行Android开发
转载请注明http://www.cnblogs.com/adong7639/p/4119467.html 无意中发现了Visual GDB这个工具,可以再Visual Studio中进行Android ...