模板汇总——LCT】的更多相关文章

link-cut tree #define lch(x) tr[x].son[0] #define rch(x) tr[x].son[1] ; struct Node{ int rev, rt; ], pre; int mx, val, id; void init(){ rt = ; rev = pre = son[] = son[] = ; mx = val = id = ; } }tr[N]; void Push_Rev(int x){ if(!x) return ; swap(lch(x)…
模板—数据结构—LCT Code: #include <cstdio> #include <algorithm> using namespace std; #define N 300010 int fa[N],son[N][2],size[N],n,m;long long sum[N],num[N]; bool rev[N]; bool check(int p) {return son[fa[p]][1]==p;} bool isroot(int p) {return son[fa…
一:dijkstra算法时间复杂度,用优先级队列优化的话,O((M+N)logN)求单源最短路径,要求所有边的权值非负.若图中出现权值为负的边,Dijkstra算法就会失效,求出的最短路径就可能是错的. 设road[i][j]表示相邻的i到j的路长U集合存储已经求得的到源点最短路径的节点,S集合表示还没求得的节点dis[i]表示i到源节点(设为0)的最短路径vis[i]=1表示i节点在U集合中 刚开始dis[0]=0,vis[0]=1;dis[i]=maxn,vis[i]=0;for 1 to…
update:2017.09.26 #include <bits/stdc++.h> using namespace std; struct Link_Cut_Tree { + ; ], fa[MAXN], rev[MAXN], sz[MAXN]; int sk[MAXN]; bool isroot(int x) { ] != x && ch[fa[x]][] != x; } void reverse(int x) { rev[x] ^= , swap(ch[x][],ch[x…
图论 数据结构 数学 其他: 洛谷模板:a,b两个字符串,求b串在a串中出现的位置 #include<iostream> #include<cstdio> #include<cstring> using namespace std; ],s2[]; ]; int main(){ scanf(,s2+); len1=strlen(s1+);len2=strlen(s2+); ,k=;i<=len2;i++){ ]&&k>;k=Next[k]);…
1. kmp 相当于往前求出一段字符信息,使得 这段字符信息和前缀相等. void getnext(){ , j = ; nx[] = -; while(j < m){ || b[j] == b[k]) nx[++j] = ++k; else k = nx[k]; } } 例: T #include<iostream> using namespace std; +], b[+], a[+]; int n, m; void getnext(){ , j = ; nx[] = -; whil…
AC自动机 模板题 HDU-2222 Keywords Search #include<bits/stdc++.h> using namespace std; #define LL long long #define ULL unsigned LL #define fi first #define se second #define lson l,m,rt<<1 #define rson m+1,r,rt<<1|1 #define max3(a,b,c) max(a,m…
核心思想: 动态维护一个森林.支持删边,加边,查询链信息等很多操作. 由若干棵$Splay$组成,每棵$Splay$维护一条链,以深度作为关键字. 也就是说$Splay$的中序遍历相当于从上到下遍历这条链. $Splay$中的边是实边,将两个$Splay$相连的边是虚边. 实边的父亲有它这个儿子(双向关系),虚边的父亲没有它这个儿子(单向关系). 组成$LCT$的基础操作:(以下均认为$LCT$中只有一棵树) $access(x)$:打通根到$x$的路径,使一棵包含且仅包含根到$x$这条链上点的…
都是作者累积的,且看其珍惜,大家可以尽量可以保存一下,如果转载请写好出处https://www.cnblogs.com/pythonywy 一.md5加密 1.简介 这是一种使用非常广泛的加密方式,不可逆的,常见16位和32位一般都是md5 import hashlib data = '你好' print(hashlib.md5(data.encode(encoding="UTF-8")).hexdigest()) #32位 print(hashlib.md5(data.encode(…
1.POJ1258 水水的prim……不过poj上硬是没过,wikioi上的原题却过了 #include<cstring> #include<algorithm> #include<cstdio> using namespace std; ,inf=1e8; ],g[maxn+][maxn+],ans=,n; ]; int main() { scanf("%d",&n); ;i<=n;++i) ;j<=n;++j) { scanf…