Qtree3 - 树链剖分
打完以后才发现写复杂了……算了懒得改了
#include <bits/stdc++.h>
using namespace std; int dep[],fa[][],size[],wson[],vis[],sid[],tid[];
int n,m,t1,t2,t3,t4,ind,top[],a[]; vector <int> g[]; void dfs1(int p) {
size[p]=;
vis[p]=;
for(int i=;i<g[p].size();i++) {
if(vis[g[p][i]]) continue;
dep[g[p][i]]=dep[p]+;
fa[g[p][i]][]=p;
dfs1(g[p][i]);
size[p]+=size[g[p][i]];
if(size[g[p][i]]>size[wson[p]]) wson[p]=g[p][i];
}
} void dfs2(int p) {
vis[p]=;
sid[p]=++ind;
tid[ind]=p;
if(wson[p]) {
top[wson[p]]=top[p];
dfs2(wson[p]);
}
for(int i=;i<g[p].size();i++) {
if(vis[g[p][i]]) continue;
top[g[p][i]]=g[p][i];
dfs2(g[p][i]);
}
} void lca_presolve() {
for(int i=;i<=;i++)
for(int j=;j<=n;j++)
fa[j][i]=fa[fa[j][i-]][i-];
} int lca(int p,int q) {
if(dep[p]<dep[q]) swap(p,q);
for(int i=;i>=;i--) if(dep[fa[p][i]]>=dep[q]) p=fa[p][i];
for(int i=;i>=;i--) if(fa[p][i]-fa[q][i]) p=fa[p][i], q=fa[q][i];
if(p-q) p=fa[p][], q=fa[q][];
return max(p,q);
} void pushup(int p){
if(a[p*]) a[p]=a[p*];
else a[p]=a[p*+];
} void modify(int p,int l,int r,int pos) {
if(l==r) {
a[p]=a[p]?:l;
return;
}
if(pos<=(l+r)/) modify(p*,l,(l+r)/,pos);
else modify(p*+,(l+r)/+,r,pos);
pushup(p);
} int query(int p,int l,int r,int ql,int qr) {
if(l>qr||r<ql) return ;
if(l>=ql&&r<=qr) return a[p];
int q0=query(p*,l,(l+r)/,ql,qr);
if(q0) return q0;
else return query(p*+,(l+r)/+,r,ql,qr);
} void tmodify(int pos) {
modify(,,n,sid[pos]);
} int lquery_upward(int anc,int son) {
int ans=;
while(dep[top[son]]>dep[anc]) {
ans=query(,,n,sid[top[son]],sid[son]);
son=fa[top[son]][];
if(ans) return ans;
}
return query(,,n,sid[anc],sid[son]);
} int lquery_downward(int anc,int son) {
int ans=,tmp;
while(dep[top[son]]>dep[anc]) {
tmp=query(,,n,sid[top[son]],sid[son]);
if(tmp) ans=tmp;
son=fa[top[son]][];
}
tmp=query(,,n,sid[anc],sid[son]);
if(tmp) ans=tmp;
return ans;
} int tquery(int p,int q){
int l=lca(p,q),tmp;
tmp=lquery_upward(l,p);
if(tmp) return tmp;
else return lquery_downward(l,q);
} int main(){
ios::sync_with_stdio(false);
cin>>n>>m;
for(int i=;i<n;i++) cin>>t1>>t2, g[t1].push_back(t2), g[t2].push_back(t1);
dep[]=; dfs1();
memset(vis,,sizeof vis);
dfs2();
lca_presolve(); for(int i=;i<=m;i++) {
cin>>t1>>t2;
if(t1==) tmodify(t2);
else t3=tid[tquery(,t2)], cout<<(t3==?-:t3)<<endl;
}
}
Qtree3 - 树链剖分的更多相关文章
- 树链剖分&咕咕咕了好久好久的qtree3
前言 显然qtree系列都是树链剖分辣 发现自己没有专门整理过树链剖分耶 辣么就把这篇博客魔改成树链剖分好辣(貌似除了树剖也没什么好写的) 正文 废话了辣么多终于开始了 一.树剖怎么写鸭 二.树剖有什 ...
- QTREE3 spoj 2798. Query on a tree again! 树链剖分+线段树
Query on a tree again! 给出一棵树,树节点的颜色初始时为白色,有两种操作: 0.把节点x的颜色置反(黑变白,白变黑). 1.询问节点1到节点x的路径上第一个黑色节点的编号. 分析 ...
- Qtree3题解(树链剖分(伪)+线段树+set)
外话:最近洛谷加了好多好题啊...原题入口 这题好像是SPOJ的题,挺不错的.看没有题解还是来一篇... 题意: 很明显吧.. 题解: 我的做法十分的暴力:树链剖分(伪)+线段树+\(set\)... ...
- Qtree3题解(树链剖分+线段树+set)
外话:最近洛谷加了好多好题啊...原题入口 这题好像是SPOJ的题,挺不错的.看没有题解还是来一篇... 题意 很易懂吧.. 题解 我的做法十分的暴力:树链剖分(伪)+线段树+ std :: set ...
- 树链剖分【p4116】Qtree3 - Query on a tree
Description 给出N个点的一棵树(N-1条边),节点有白有黑,初始全为白 有两种操作: 0 i : 改变某点的颜色(原来是黑的变白,原来是白的变黑) 1 v : 询问1到v的路径上的第一个黑 ...
- 【SPOJ-QTREE3】树链剖分
http://www.spoj.com/problems/QTREE3/ 时间限制:2s 代码长度限制:50000B 内存限制:1536MB [题目描述] 给出N个点的一棵树(N-1条边 ...
- 【模板时间】◆模板·II◆ 树链剖分
[模板·II]树链剖分 学长给我讲树链剖分,然而我并没有听懂,还是自学有用……另外感谢一篇Blog +by 自为风月马前卒+ 一.算法简述 树链剖分可以将一棵普通的多叉树转为线段树计算,不但可以实现对 ...
- BZOJ 3626: [LNOI2014]LCA [树链剖分 离线|主席树]
3626: [LNOI2014]LCA Time Limit: 10 Sec Memory Limit: 128 MBSubmit: 2050 Solved: 817[Submit][Status ...
- BZOJ 1984: 月下“毛景树” [树链剖分 边权]
1984: 月下“毛景树” Time Limit: 20 Sec Memory Limit: 64 MBSubmit: 1728 Solved: 531[Submit][Status][Discu ...
随机推荐
- dubbo初识
1.什么是dubbo? dubbo 是一个分布式服务框架 是一个高性能的RPC框架 它提供了三大核心能力:面向接口的远程方法调用,智能容错和负载均衡,以及服务自动注册和发现. 谈到了分布式服务框架 那 ...
- MySQL 普通索引和唯一索引的区别
该文为< MySQL 实战 45 讲>的学习笔记,感谢查看,如有错误,欢迎指正 一.查询和更新上的区别 这两类索引在查询能力上是没差别的,主要考虑的是对更新性能的影响.建议尽量选择普通索引 ...
- 彻底理解Windows认证1
彻底理解Windows认证 一.Windows本地认证 1. 我的密码在哪里? 路径:C:\Windows\System32\config\SAM 当我们登录系统的时候,系统会自动的读取SAM文件中的 ...
- 黑龙江大学图书馆抢座python
2019.11.01 增加成功发送QQ邮件. 2019.10.31更新 晚上测试成功 ========================== 昨晚肝了一晚上,今天已经写出成品并且部署到服务器上了,代码很 ...
- spring cloud微服务快速教程之(十) gateway 服务网关
0.前言 gateway是spring的二代网关, 作为Netflix Zuul的替代者,是异步非阻塞网关 ,ZUUL2也是异步非阻塞的,但未纳入spring cloud整合计划 基于WebFlux ...
- linux操作系统搭建测试环境
环境:linux操作系统.tomcat服务器.mysql数据库.火狐浏览器 工具:secureCRT.FileZalla 一.安装vmware虚拟机 二.在虚拟机上安装linux操作系统,参考http ...
- 吴裕雄--天生自然 PYTHON数据分析:人类发展报告——HDI, GDI,健康,全球人口数据数据分析
import pandas as pd # Data analysis import numpy as np #Data analysis import seaborn as sns # Data v ...
- MySQL 8 用户定义函数
MySQL Server可以通过创建或者加载UDFs(User-Defined Functions)来扩展服务器功能. 通过CREATE FUNCTION语句加载 UDF,比如: CREATE FUN ...
- Mysql-分库分区分表
大数据-分表分区分库问题集:1.分表时两张表的数据都一样么?如果一样,只是降低了表的访问量,但是如果数据多了还是没有提高查询的效率答:分表是对一张表中的数据按照某种规则进行拆分到三张表中,三张表的所有 ...
- [TJOI2008] 小偷
TJOI2008小偷 题目背景 一位著名的小偷进入了一个充满宝石的储藏室,这个储藏室是由一连串房间构成的,房间的标号从0开始,想进入第i个房间就必须从第i-1个房间进入,如图: 题目描述 上图为三个房 ...