打完以后才发现写复杂了……算了懒得改了

 #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 - 树链剖分的更多相关文章

  1. 树链剖分&咕咕咕了好久好久的qtree3

    前言 显然qtree系列都是树链剖分辣 发现自己没有专门整理过树链剖分耶 辣么就把这篇博客魔改成树链剖分好辣(貌似除了树剖也没什么好写的) 正文 废话了辣么多终于开始了 一.树剖怎么写鸭 二.树剖有什 ...

  2. QTREE3 spoj 2798. Query on a tree again! 树链剖分+线段树

    Query on a tree again! 给出一棵树,树节点的颜色初始时为白色,有两种操作: 0.把节点x的颜色置反(黑变白,白变黑). 1.询问节点1到节点x的路径上第一个黑色节点的编号. 分析 ...

  3. Qtree3题解(树链剖分(伪)+线段树+set)

    外话:最近洛谷加了好多好题啊...原题入口 这题好像是SPOJ的题,挺不错的.看没有题解还是来一篇... 题意: 很明显吧.. 题解: 我的做法十分的暴力:树链剖分(伪)+线段树+\(set\)... ...

  4. Qtree3题解(树链剖分+线段树+set)

    外话:最近洛谷加了好多好题啊...原题入口 这题好像是SPOJ的题,挺不错的.看没有题解还是来一篇... 题意 很易懂吧.. 题解 我的做法十分的暴力:树链剖分(伪)+线段树+ std :: set ...

  5. 树链剖分【p4116】Qtree3 - Query on a tree

    Description 给出N个点的一棵树(N-1条边),节点有白有黑,初始全为白 有两种操作: 0 i : 改变某点的颜色(原来是黑的变白,原来是白的变黑) 1 v : 询问1到v的路径上的第一个黑 ...

  6. 【SPOJ-QTREE3】树链剖分

    http://www.spoj.com/problems/QTREE3/ 时间限制:2s    代码长度限制:50000B     内存限制:1536MB [题目描述] 给出N个点的一棵树(N-1条边 ...

  7. 【模板时间】◆模板·II◆ 树链剖分

    [模板·II]树链剖分 学长给我讲树链剖分,然而我并没有听懂,还是自学有用……另外感谢一篇Blog +by 自为风月马前卒+ 一.算法简述 树链剖分可以将一棵普通的多叉树转为线段树计算,不但可以实现对 ...

  8. BZOJ 3626: [LNOI2014]LCA [树链剖分 离线|主席树]

    3626: [LNOI2014]LCA Time Limit: 10 Sec  Memory Limit: 128 MBSubmit: 2050  Solved: 817[Submit][Status ...

  9. BZOJ 1984: 月下“毛景树” [树链剖分 边权]

    1984: 月下“毛景树” Time Limit: 20 Sec  Memory Limit: 64 MBSubmit: 1728  Solved: 531[Submit][Status][Discu ...

随机推荐

  1. 1.3.6 详解build.gradle文件——Android第一行代码(第二版)笔记

    不同于Eclipse,Android Studio是采用Gradle来构建项目的.Gradle是一个非常先进的项目构建工具,它使用了一种基于Groovy的领域特定语言(DSL)来声明项目设置. 首先看 ...

  2. Linux学习Day5:Vim编辑器、配置网卡、配置Yum软件仓库

    今天首先学习Vim编辑器的使用,通过它可以对Linux系统的文件进行编写和修改.在Linux系统中一切都是文件,所以熟练掌握Vim编辑器的使用十分重要.最后通过配置主机网卡的实验,来加深Vim编辑器中 ...

  3. Windows10官方原版系统下载安装制作方法

    Windows10官方原版系统下载安装制作方法 去官网下载系统安装程序 点进去 https://www.microsoft.com/zh-cn/software-download/windows10 ...

  4. Python中autoescape标签使用详解

    1.spaceless标签:移除html标签中的空白字符.包括空格.tab键.换行符,示例代码如下: {% spaceless %}具体内容{% endspaceless %} 2.autoescap ...

  5. JS隐藏显示图片

    <!DOCTYPE html> <html lang="en"> <head>     <meta charset="UTF-8 ...

  6. 【DTOJ】1001:长方形周长和面积

    DTOJ 1001:长方形周长和面积  解题报告 2017.11.05 第一版  ——由翱翔的逗比w原创 题目信息: 题目描述 已知长方形的长和宽,求长方形的周长和面积? 输入 一行:空格隔开的两个整 ...

  7. C语言 getchar

    C语言 getchar getchar是从标准输入设备读取一个char. 案例 #define _CRT_SECURE_NO_WARNINGS #include <stdio.h> #in ...

  8. Intel 8086 标志寄存器及JCC指令表

    汇编 JCC指令表 JCC指条件跳转指令,CC就是指条件码. JCC指令 中文含义 英文原意 检查符号位 典型C应用 JZ/JE 若为0则跳转:若相等则跳转 jump if zero;jump if ...

  9. C#MVC用ZXing.Net生成二维码/条形码

    开篇:zxing.net是.net平台下编解条形码和二维码的工具. 首先创建新项目 选择MVC模板  添加一个控制器  在项目引用中的引用ZXing 进行联网下载 控制器需要引用 后台控制器   pu ...

  10. nunjucks如何使用?

    基本的使用 const nunjucks = require('nunjucks') // nunjucks.configure({ autoescape: true }); // const res ...