【洛谷 p3379】模板-最近公共祖先(图论--倍增算法求LCA)
题目:给定一棵有根多叉树,请求出指定两个点直接最近的公共祖先。
解法:倍增。
1 #include<cstdio>
2 #include<cstdlib>
3 #include<cstring>
4 #include<iostream>
5 using namespace std;
6 #define N 500010
7 #define D 20
8
9 int n,m,root,len=0;
10 int last[N],fa[N][D],dep[N];
11 struct edge{int x,y,next;}a[2*N];
12
13 void ins(int x,int y)
14 {
15 a[++len].x=x,a[len].y=y;
16 a[len].next=last[x],last[x]=len;
17 }
18 void build(int x,int f)
19 {
20 fa[x][0]=f, dep[x]=dep[f]+1;
21 for (int i=1;i<=D && (1<<i)<=dep[x];i++)
22 fa[x][i]=fa[fa[x][i-1]][i-1];
23 for (int i=last[x];i!=-1;i=a[i].next)
24 if (a[i].y!=f) build(a[i].y,x);
25 }
26 int LCA(int x,int y)
27 {
28 if (dep[x]<dep[y]) {int t;t=x,x=y,y=t;}
29 if (dep[x]!=dep[y])
30 for (int i=D;i>=0;i--)
31 if (dep[x]>=(1<<i)+dep[y]) x=fa[x][i];
32 if (x==y) return x;
33 for (int i=D;i>=0;i--)
34 if (dep[x]>=(1<<i) && fa[x][i]!=fa[y][i])
35 x=fa[x][i],y=fa[y][i];
36 return fa[x][0];
37 }
38 int main()
39 {
40 scanf("%d%d%d",&n,&m,&root);
41 int x,y;
42 memset(last,-1,sizeof(last));
43 for (int i=1;i<n;i++)
44 {
45 scanf("%d%d",&x,&y);
46 ins(x,y),ins(y,x);
47 }
48 dep[0]=0, build(root,0);//由于是0,x,y之间的最大距离就是fa[x][i],(1<<i)<=dep[x]-dep[y]
49 while (m--)
50 {
51 scanf("%d%d",&x,&y);
52 printf("%d\n",LCA(x,y));
53 }
54 return 0;
55 }
【洛谷 p3379】模板-最近公共祖先(图论--倍增算法求LCA)的更多相关文章
- caioj 1236 最近公共祖先  树倍增算法模版 倍增
		
[题目链接:http://caioj.cn/problem.php?id=1236][40eebe4d] 代码:(时间复杂度:nlogn) #include <iostream> #inc ...
 - 洛谷.3809.[模板]后缀排序(后缀数组 倍增) & 学习笔记
		
题目链接 //输出ht见UOJ.35 #include<cstdio> #include<cstring> #include<algorithm> const in ...
 - 洛谷P3373 [模板]线段树 2(区间增减.乘 区间求和)
		
To 洛谷.3373 [模板]线段树2 题目描述 如题,已知一个数列,你需要进行下面两种操作: 1.将某区间每一个数加上x 2.将某区间每一个数乘上x 3.求出某区间每一个数的和 输入输出格式 输入格 ...
 - 洛谷P1155 双栈排序题解(图论模型转换+二分图染色+栈)
		
洛谷P1155 双栈排序题解(图论模型转换+二分图染色+栈) 标签:题解 阅读体验:https://zybuluo.com/Junlier/note/1311990 原题地址:洛谷P1155 双栈排序 ...
 - 倍增法求lca(最近公共祖先)
		
倍增法求lca(最近公共祖先) 基本上每篇博客都会有参考文章,一是弥补不足,二是这本身也是我学习过程中找到的觉得好的资料 思路: 大致上算法的思路是这样发展来的. 想到求两个结点的最小公共祖先,我们可 ...
 - P5836 [USACO19DEC]Milk Visits S  从并查集到LCA(最近公共祖先) Tarjan算法 (初级)
		
为什么以它为例,因为这个最水,LCA唯一黄题. 首先做两道并查集的练习(估计已经忘光了).简单来说并查集就是认爸爸找爸爸的算法.先根据线索理认爸爸,然后查询阶段如果发现他们的爸爸相同,那就是联通一家的 ...
 - 洛谷P3379 【模板】最近公共祖先(LCA)
		
P3379 [模板]最近公共祖先(LCA) 152通过 532提交 题目提供者HansBug 标签 难度普及+/提高 提交 讨论 题解 最新讨论 为什么还是超时.... 倍增怎么70!!题解好像有 ...
 - 洛谷P3379 【模板】最近公共祖先(LCA)(dfs序+倍增)
		
P3379 [模板]最近公共祖先(LCA) 题目描述 如题,给定一棵有根多叉树,请求出指定两个点直接最近的公共祖先. 输入输出格式 输入格式: 第一行包含三个正整数N.M.S,分别表示树的结点个数.询 ...
 - 洛谷——P3379 【模板】最近公共祖先(LCA)
		
P3379 [模板]最近公共祖先(LCA) 题目描述 如题,给定一棵有根多叉树,请求出指定两个点直接最近的公共祖先. 输入输出格式 输入格式: 第一行包含三个正整数N.M.S,分别表示树的结点个数.询 ...
 
随机推荐
- maven 无法导入ojdbc 的jar包 解决方法
			
由于maven无法在线安装ojdbc包,所有先在我们需要手动导入. 准备环境: 1.系统需要配置好jdk以及maven环境. 2.ojdbc的jar包,记住jar的路径,我的路径是:E:\jdbc\o ...
 - LeetCode485 最大连续1的个数
			
给定一个二进制数组, 计算其中最大连续1的个数. 示例 1: 输入: [1,1,0,1,1,1] 输出: 3 解释: 开头的两位和最后的三位都是连续1,所以最大连续1的个数是 3. 注意: 输入的数组 ...
 - pip不是内部或外部命令解决方法
			
问题 已经配置好Python环境,但是安装依赖时,出现pip不是内部或外部命令. 解决方法 找到pip.exe文件所在的目录,将所在路径配置到环境变量path中. 再次输入pip
 - Java 反射修改类的常量值、静态变量值、属性值
			
前言 有的时候,我们需要修改一个变量的值,但变量也许存在于 Jar 包中或其他位置,导致我们不能从代码层面进行修改,于是我们就用到了下面的场景,通过反射来进行修改变量的值. 定义一个实体类 class ...
 - 2021年正确的Android逆向开发学习之路
			
2021年正确的Android逆向开发学习之路 说明 文章首发于HURUWO的博客小站,本平台做同步备份发布.如有浏览或访问异常或者相关疑问可前往原博客下评论浏览. 原文链接 2021年正确的Andr ...
 - SDUST数据结构 - chap9 排序
			
判断题: 选择题: 编程题: 7-1 排序: 输入样例: 11 4 981 10 -17 0 -20 29 50 8 43 -5 输出样例: -20 -17 -5 0 4 8 10 29 43 50 ...
 - 【Not BUG】微软Winform窗体中设计上的Bug,会导致程序编译失败?不,这不是BUG!
			
这不是BUG!!! 原文地址: https://www.cnblogs.com/thanks/p/14302011.html 现在让我们回忆一下原文 原文的操作步骤: 1. 新建一个Window Fo ...
 - qt for webassembly环境搭建图文教程
			
一.前言 从Qt5.14开始,官方的在线安装提供了qt for webassembly构建套件,这对很多小白来说绝对是个好消息,也绝对是个好东西,好消息是不用再去交叉编译自己生成qt for weba ...
 - 推荐几个学习Python的免费网站
			
想要学好Python,只靠看Python相关的书籍是远远不够的!今天为大家分享几个实用的Python学习网站. 欢迎各位热爱Python的小伙伴进群交流:610380249群里有大佬哦,而且很热心,群 ...
 - 解决Python内CvCapture视频文件格式不支持问题
			
解决Python内CvCapture视频文件格式不支持问题 在读取视频文件调用默认的摄像头cv.VideoCapture(0)会出现下面的视频格式问题 CvCapture_MSMF::initStre ...