首页 > TAG信息列表 > P3379

洛谷-P3379 【模板】最近公共祖先(LCA)

【模板】最近公共祖先(LCA) 倍增 lca 模板 真心觉得二进制太奇妙了 #include <iostream> #include <cstdio> #include <algorithm> #include <vector> using namespace std; #define endl '\n' const int maxn = 5e5 + 10; vector<int>gra[maxn]; int fa[maxn

P3379 -【模板】最近公共祖先(LCA)

题目链接:点击进入 题目 思路 倍增求lca( 最近公共祖先 ) 代码 // Problem: P3379 【模板】最近公共祖先(LCA) // Contest: Luogu // URL: https://www.luogu.com.cn/problem/P3379 // Memory Limit: 500 MB // Time Limit: 1500 ms // // Powered by CP Editor (https://cpedi

P3379&&ybtoj【数据结构】5章3题【【模板】最近公共祖先(LCA)】

【模板】最近公共祖先(LCA) 题目 P3379 注:ybtoj问的是两点距离,即 d r o o t

洛谷P3379 -【模板】最近公共祖先 - 倍增法求LCA - ST求LCA模板题

题目链接 https://www.luogu.com.cn/problem/P3379 算法分析 需要尽可能的向上跳,但是两者之间不能相遇。(因为如果相遇了,那么很有可能,虽然是公共祖先,但是未必是最近的) 倍增法:“倍增”就是指跳的时候是以\(2^n\)而不是一个一个跳,并且是从大数往小数跳。 时间复杂度 AC代码

P3379 【模板】最近公共祖先(LCA)

luogu P3379 LCA 题目链接 传送门 #include <bits/stdc++.h> using namespace std; const int N = 5e5 + 10; int nxt[N<<1],head[N],to[N<<1],tot; void add(int u,int v) { nxt[++tot] = head[u]; head[u] = tot; to[tot] = v; } int depth[N],fa[N]

P3379 【模板】最近公共祖先(LCA)

P3379 【模板】最近公共祖先(LCA) LCA模板 询问离线 tarjan算法 #include<bits/stdc++.h>using namespace std;vector<int> v[500000+5];int N,M,root;bool vis[500000+5];struct Q{ int x,y; int id; bool operator< (Q a) { if(a.x==x)return y<a.y; ret

洛谷 P3379 【模板】最近公共祖先(LCA)

题目传送门 解题思路: 自己懒得写,看一位大佬写的不错(三种方法)。//任意门 AC代码: 倍增做法: 1 #include<iostream> 2 #include<cstdio> 3 #include<cstring> 4 5 using namespace std; 6 7 int n,m,s,head[500002],tot,d[500002],p[500002][21]; 8 struct kkk { 9 int v,next;

Luogu p3379(LCA)

传送门 题意: 求一颗nnn个节点的树的LCALCALCA 题目分析: 复习+学习一下三种不同LCALCALCA的求法(特别是根据欧拉序+STSTST表求LCALCALCA)的方法。 下面简单总结(借鉴)一下LCALCALCA的三种求法 代码: 树上倍增算法(在线),预处理时间复杂度O(nlogn)\mathcal{O}(nlogn)O(nlogn),每次询问的

P3379 【模板】最近公共祖先(LCA)(树链剖分)版

#include <bits/stdc++.h> #define read read() #define up(i,l,r) for(register int i = (l);i <= (r);i++) #define down(i,l,r) for(register int i = (l);i >= (r);i--) #define traversal_vedge(i) for(register int i = head[u]; i ;i = e[i].nxt) #define