hdu - 2586 (LCA板子题)
(这次的英文题面要比上一个容易看多了)
(英语蒟蒻的卑微)
又是一个很裸的LCA题
(显然,这次不太容易打暴力咧)
(但听说还是有大佬用dfs直接a掉了)
正好
趁这个机会复习一下LCA
这里用的是倍增lca
的思想(一不小心是会写tle的吧)
(也有可能是因为我太弱了才t掉的)
我才不会说我有一次卑微了
一开始看PPT
以为自己明白了
结果发现
有一点点问题
由于本题中这个树是题里给的
所以节点的编号不可以简简单单认为是从上到下从左到右顺序排列的
(但其实这部算什么大问题啊qwq)
(还是我太弱了)
长记性了的我这次记住了要加'\n'
#include<cstdio>
#include<iostream>
#include<cstring>
#define maxn 40000
using namespace std; struct EDGE
{
int nxt,to,v;
}edge[maxn*+]; int T,n,root,cnt,m;
int head[maxn+],dep[maxn+],dis[maxn+];
int f[maxn+][];
bool vis[maxn+]; void add(int x,int y,int z)
{
edge[++cnt].to=y;
edge[cnt].v=z;
edge[cnt].nxt=head[x];
head[x]=cnt;
} void dfs(int u,int fa)
{
dep[u]=dep[fa]+;
for(int i=; i<=; i++)
{
f[u][i+]=f[f[u][i]][i];
}
for(int i=head[u]; i; i=edge[i].nxt)
{
if(edge[i].to==fa)
{
continue;
}
dis[edge[i].to]=dis[u]+edge[i].v;
f[edge[i].to][]=u;
dfs(edge[i].to,u);
}
} int LCA(int x,int y)
{
if(dep[x]<dep[y])
{
swap(x,y);
}
for(int i=; i>=; i--)
{
if(dep[f[x][i]]>=dep[y])
{
x=f[x][i];
}
if(x==y)
{
return x;
}
}
for(int i=; i>=; i--)
{
if(f[x][i]!=f[y][i])
{
x=f[x][i];
y=f[y][i];
}
}
return f[x][];
} int main()
{
scanf("%d",&T);
while(T--)
{
memset(vis,,sizeof(vis));
memset(edge,,sizeof(edge));
memset(f,,sizeof(f));
memset(dep,,sizeof(dep));
memset(head,,sizeof(head));
memset(dis,,sizeof(dis));
cnt=;
scanf("%d%d",&n,&m);
for(int i=; i<=n-; i++)
{
int x,y,z;
scanf("%d%d%d",&x,&y,&z);
vis[y]=;
add(x,y,z);
add(y,x,z);
}
for(int i=; i<=n; i++)
{
if(vis[i]==)
{
root=i;
break;
}
}
dfs(root,);
for(int i=; i<=m; i++)
{
int a,b;
scanf("%d%d",&a,&b);
printf("%d\n",dis[a]+dis[b]-*dis[LCA(a,b)]);
}
}
return ;
}
hdu - 2586 (LCA板子题)的更多相关文章
- HDU 2586 (LCA模板题)
题目链接: http://acm.hdu.edu.cn/showproblem.php?pid=2586 题目大意:在一个无向树上,求一条链权和. 解题思路: 0 | 1 / \ 2 3 ...
- [hdu 2586]lca模板题(在线+离线两种版本)
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=2586 在线版本: 在线方法的思路很简单,就是倍增.一遍dfs得到每个节点的父亲,以及每个点的深度.然后 ...
- bzoj-1787-洛谷-4281(LCA板子题)
传送门(bzoj) 传送门(洛谷) 可以说这道也是一个板子题 由于题中是三个人需经过的路径最短 就会有一点点不太一样 那么 就两两求LCA 这样之后就会出现两种状况 一.所得到的三个LCA是相等的 那 ...
- HDU 2586 ( LCA/tarjan算法模板)
链接:http://acm.hdu.edu.cn/showproblem.php?pid=2586 题意:n个村庄构成一棵无根树,q次询问,求任意两个村庄之间的最短距离 思路:求出两个村庄的LCA,d ...
- hdu 2586(LCA在线ST)
How far away ? Time Limit: / MS (Java/Others) Memory Limit: / K (Java/Others) Total Submission(s): A ...
- HDU 2586 LCA
题目大意: 多点形成一棵树,树上边有权值,给出一堆询问,求出每个询问中两个点的距离 这里求两个点的距离可以直接理解为求出两个点到根节点的权值之和,再减去2倍的最近公共祖先到根节点的距离 这是自己第一道 ...
- hdu 2586 lca在线算法(朴素算法)
#include<stdio.h> #include<string.h>//用c/c++会爆栈,用g++ac #define inf 0x3fffffff #define N ...
- HDU 2586 How far away ? (LCA)
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=2586 LCA模版题. RMQ+LCA: #include <iostream> #incl ...
- HDU - 2586 How far away ?(LCA模板题)
HDU - 2586 How far away ? Time Limit: 1000MS Memory Limit: 32768KB 64bit IO Format: %I64d & ...
随机推荐
- HDU 4764 Stone(巴什博奕)
Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others)Total Submission( ...
- Phaser.js之简单的跑酷游戏
采用的物理引擎是Phaser.js 官网地址:http://phaser.io/ 在这里对此引擎不做过多介绍(因为我也是小白,嘿嘿) 效果展示: 源码(详细源码图片资源可点击文章下方或屏幕右上方的gi ...
- web框架的本质
一 web框架的本质及自定义web框架 我们可以这样理解:所有的Web应用本质上就是一个socket服务端,而用户的浏览器就是一个socket客户端,基于请求做出响应,客户都先请求,服务端做出对应的响 ...
- 33.Odoo产品分析 (四) – 工具板块(4) – 问题追踪及群发邮件营销(1)
查看Odoo产品分析系列--目录 问题追踪 该应用程序允许您管理项目中可能遇到的问题,如系统中的bug.客户投诉或物料故障. 该模块安装后没有菜单显示,而是作为后台管理,接收一些问题报告. 群发邮件 ...
- Android--小游戏
GitHub:https://github.com/vinieo/game 功能描述 “猜小球”是一个简单的愉悦身心的小游戏,它的功能结构如图a-1所示. 构建开发环境 在开发本游戏时,首先需要下 ...
- (后端)Spring手动回滚事务
百度上查资料获得的 throw new RuntimeException(); 或者 TransactionAspectSupport.currentTransactionStatus().setR ...
- 图文并茂 RAID 技术全解 – RAID0、RAID1、RAID5、RAID10
RAID 技术相信大家都有接触过,尤其是服务器运维人员,RAID 概念很多,有时候会概念混淆.这篇文章为网络转载,写得相当不错,它对 RAID 技术的概念特征.基本原理.关键技术.各种等级和发展现状进 ...
- CentOS6.5内 Oracle 11GR2静默安装
一.修改配置文件 1.1.修改/etc/security/limits.conf文件,修改用户的SHELL的限制. 输入命令:vi /etc/security/limits.conf,将下列内容加入该 ...
- c/c++ 编译器提供的默认6个函数
c/c++ 编译器提供的默认6个函数 1,构造函数 2,拷贝构造函数 3,析构函数 4,=重载函数 5,&重载函数 6,const&重载函数 #include <iostream ...
- kali系统固化到固态硬盘小记(赠送给广大折腾党的笔记)
1.首先你需要一个移动硬盘和一个移动硬盘盒子(一根数据转换线,一般买盒子商家会赠送的) SSD硬盘要事先格式化一下格式,不然识别不出来 2.准备好Kali镜像,传送门在这里https://www.ka ...