当前位置: 首页 > news >正文

信息学奥赛一本通 1552:【例 1】点的距离

【题目链接】

ybt 1552:【例 1】点的距离

【题目考点】

1. 最近公共祖先(LCA):倍增求LCA

知识点讲解见:洛谷 P3379 【模板】最近公共祖先(LCA)

【解题思路】

首先用邻接表保存输入的无权图。
使用倍增求LCA的解题方法:设dep数组,depudep_udepu表示顶点u的深度。设fa数组,fai,jfa_{i,j}fai,j表示从结点i开始向上走2j2^j2j步可以到达的结点。
而后对该图做深度优先遍历,可以预处理求出dep数组和fa数组,同时也将该图变为了有根树。
该图是无权图,可以认为每条边长度为1。
无权有根树上,根结点到一个结点的路径长度为该结点的深度(根结点深度为0)。
树上任意两结点之间存在唯一的路径。记结点x到结点y的路径长度为Dis(x,y)Dis(x, y)Dis(x,y)
结点x到结点y的路径必然经过二者的最近公共祖先LCA(x, y)。
已知根结点r到x的路径长度为dep[x],根结点r到y的路径长度为dep[y]
根结点r到x的路径可以分为r到LCA(x,y)的路径,以及LCA(x, y)到x的路径。
根结点r到y的路径可以分为r到LCA(x,y)的路径,以及LCA(x, y)到y的路径。
二者相加后,总长度包括x到LCA(x, y)的路径长度,LCA(x, y)到y的路径长度,以及两倍的r到LCA(x, y)的路径长度。即x到y的路径长度加上两倍的LCA(x, y)的深度。
因此depx+depy=Dis(x,y)+2depLCA(x,y)dep_x+dep_y=Dis(x, y)+2dep_{LCA(x, y)}depx+depy=Dis(x,y)+2depLCA(x,y)
所以Dis(x,y)=depx+depy−2depLCA(x,y)Dis(x, y) = dep_x+dep_y-2dep_{LCA(x, y)}Dis(x,y)=depx+depy2depLCA(x,y)
在这里插入图片描述
使用倍增求LCA算法,每次查询Dis(x,y)Dis(x, y)Dis(x,y)的时间复杂度为O(log⁡n)O(\log n)O(logn)

【题解代码】

  • 解法1:倍增求LCA
#include<bits/stdc++.h>
using namespace std;
#define N 100005
#define LN 25
vector<int> edge[N];
int n, lg[N], dep[N], fa[N][LN];//f[i][j]:顶点i向上走2^j到达的顶点 
void initLg()
{for(int i = 2; i <= n; ++i)lg[i] = lg[i/2]+1;
}
void dfs(int u)
{for(int v : edge[u]) if(v != fa[u][0])//v不是u的父亲 {fa[v][0] = u;dep[v] = dep[u]+1;for(int j = 1; 1<<j <= dep[v]; ++j)fa[v][j] = fa[fa[v][j-1]][j-1];dfs(v);}
}
int lca(int u, int v)
{if(dep[u] < dep[v])swap(u, v);while(dep[u] > dep[v])u = fa[u][lg[dep[u]-dep[v]]];if(u == v)//如果v本身为LCA(u, v),那么当二者深度相同时,二者相同 return u;for(int k = lg[dep[u]]; k >= 0; --k)if(fa[u][k] != fa[v][k])u = fa[u][k], v = fa[v][k];return fa[u][0];
}
int main()
{ios::sync_with_stdio(false);cin.tie(nullptr);int q, x, y;cin >> n;for(int i = 1; i < n; ++i){cin >> x >> y;edge[x].push_back(y);edge[y].push_back(x);}initLg();dfs(1);cin >> q;while(q--){cin >> x >> y;cout << dep[x]+dep[y]-2*dep[lca(x, y)] << '\n';}return 0;
}

文章转载自:
http://avo.aaladrg.cn
http://ballade.aaladrg.cn
http://antispasmodic.aaladrg.cn
http://ala.aaladrg.cn
http://bailout.aaladrg.cn
http://canonization.aaladrg.cn
http://badinage.aaladrg.cn
http://alvin.aaladrg.cn
http://chemistry.aaladrg.cn
http://bullion.aaladrg.cn
http://aeroelasticity.aaladrg.cn
http://chipped.aaladrg.cn
http://baseset.aaladrg.cn
http://bield.aaladrg.cn
http://buckhound.aaladrg.cn
http://airfreighter.aaladrg.cn
http://bolshevize.aaladrg.cn
http://career.aaladrg.cn
http://biological.aaladrg.cn
http://aeruginous.aaladrg.cn
http://bourn.aaladrg.cn
http://cheryl.aaladrg.cn
http://allogamy.aaladrg.cn
http://cellulase.aaladrg.cn
http://aqualung.aaladrg.cn
http://appropriator.aaladrg.cn
http://bagdad.aaladrg.cn
http://amnesia.aaladrg.cn
http://algebraic.aaladrg.cn
http://antlion.aaladrg.cn
http://www.dtcms.com/a/281523.html

相关文章:

  • 记一次POST请求中URL中文参数乱码问题的解决方案
  • React响应式组件范式:从类组件到Hooks
  • Ubuntu 安装
  • 回收站里的文件被删除了怎么还原和恢复
  • 京存大容量存储助力“国漫之光”·玄机动画
  • 注解和反射
  • 3D视频技术全解析:从原理架构到产业应用的深度探索
  • Python文本统计分析工具
  • 集训Demo2
  • 巧用Bitset!优化dp
  • “C21988-谷物烘干机(2D+3D+说明书+运动仿真)8张cad+设计说明书
  • Eplan API SQL
  • 从灾前感知到灾后恢复:人工智能在城市气候风险管理中的全链路赋能
  • ESLint 除了在packages.json还能在哪里配置?
  • 【插件】vue-i18n的安装和使用全解
  • Nvidia服务器备份指南 (数据+环境)
  • 高防CDN与普通CDN的核心区别
  • DevOps落地的终极实践:8大关键路径揭秘!
  • Python 字典 (Dictionary) 详解
  • AI产品经理面试宝典第18天:AI思维矩阵构建与实战应用面试题与答法
  • 2HDMI/1DP转EDP/LVDS,支持4K,144HZ和240HZ.
  • zynq分频的例子
  • python学智能算法(十九)|SVM基础概念-超平面
  • Python语法入门之装饰器的基本用法
  • 硬件设计学习DAY1——电源的分类
  • js运算符
  • Java线程池深度解析与Spring Boot实战指南
  • 文献阅读 250715-Atmospheric rivers cause warm winters and extreme heat events
  • 服务器数据恢复—光纤存储硬盘扇区不稳定导致业务中断如何恢复数据?
  • 【物联网】基于树莓派的物联网开发【9】——树莓派修正系统时间五种解决方案