洛谷P4116 Qtree3(树剖+线段树)
LCT秒天秒地
树剖比较裸的题了
用线段树记录一下区间的最左边的黑点的编号(因为同一条链上肯定是最左边的深度最小,到根节点距离最近)
然后记得树剖的时候肯定是越后面的答案越优,因为深度越浅
- //minamoto
- #include<bits/stdc++.h>
- using namespace std;
- #define getc() (p1==p2&&(p2=(p1=buf)+fread(buf,1,1<<21,stdin),p1==p2)?EOF:*p1++)
- char buf[<<],*p1=buf,*p2=buf;
- inline int read(){
- #define num ch-'0'
- char ch;bool flag=;int res;
- while(!isdigit(ch=getc()))
- (ch=='-')&&(flag=true);
- for(res=num;isdigit(ch=getc());res=res*+num);
- (flag)&&(res=-res);
- #undef num
- return res;
- }
- char sr[<<],z[];int C=-,Z;
- inline void Ot(){fwrite(sr,,C+,stdout),C=-;}
- inline void print(int x){
- if(C><<)Ot();if(x<)sr[++C]=,x=-x;
- while(z[++Z]=x%+,x/=);
- while(sr[++C]=z[Z],--Z);sr[++C]='\n';
- }
- const int N=1e5+;
- int head[N],Next[N<<],ver[N<<],tot;
- inline void add(int u,int v){
- ver[++tot]=v,Next[tot]=head[u],head[u]=tot;
- }
- int dfn[N],sz[N],son[N],fa[N],bl[N],val[N],top[N],cnt,n,m;
- void dfs1(int u){
- sz[u]=;
- for(int i=head[u];i;i=Next[i]){
- int v=ver[i];
- if(v!=fa[u]){
- fa[v]=u,dfs1(v),sz[u]+=sz[v];
- if(sz[son[u]]<sz[v]) son[u]=v;
- }
- }
- }
- void dfs2(int u,int t){
- dfn[u]=++cnt,bl[cnt]=u,top[u]=t;
- if(son[u]){
- dfs2(son[u],t);
- for(int i=head[u];i;i=Next[i]){
- int v=ver[i];
- if(v!=fa[u]&&v!=son[u]) dfs2(v,v);
- }
- }
- }
- int mx[N<<];
- #define ls (p<<1)
- #define rs (p<<1|1)
- inline void upd(int p){
- mx[p]=mx[ls]?mx[ls]:mx[rs];
- }
- void build(int p,int l,int r){
- if(l==r) return (void)(mx[p]=val[bl[l]]?bl[l]:);
- int mid=(l+r)>>;
- build(ls,l,mid),build(rs,mid+,r);
- upd(p);
- }
- void update(int p,int l,int r,int x){
- if(l==r) return (void)(mx[p]=val[bl[l]]?bl[l]:);
- int mid=(l+r)>>;
- x<=mid?update(ls,l,mid,x):update(rs,mid+,r,x);
- upd(p);
- }
- int query(int p,int l,int r,int ql,int qr){
- if(ql<=l&&qr>=r) return mx[p];
- int mid=(l+r)>>,res=;
- if(ql<=mid&&(res=query(ls,l,mid,ql,qr))) return res;
- if(qr>mid&&(res=query(rs,mid+,r,ql,qr))) return res;
- return ;
- }
- inline void change(int i){
- val[i]^=,update(,,n,dfn[i]);
- }
- inline int get(int u){
- int res=,p;
- while(top[u]!=){
- p=query(,,n,dfn[top[u]],dfn[u]);
- p?res=p:;
- u=fa[top[u]];
- }
- p=query(,,n,,dfn[u]);p?res=p:;
- return res?res:-;
- }
- int main(){
- // freopen("testdata.in","r",stdin);
- n=read(),m=read();
- for(int i=,u,v;i<n;++i)
- u=read(),v=read(),add(u,v),add(v,u);
- dfs1(),dfs2(,),build(,,n);
- while(m--){
- int op=read(),u=read();
- op&?print(get(u)):change(u);
- }
- Ot();
- return ;
- }
洛谷P4116 Qtree3(树剖+线段树)的更多相关文章
- 洛谷P4315 月下“毛景树”(树剖+线段树)
传送门 woc这该死的码农题…… 把每一条边转化为它连接的两点中深度较深的那一个,然后就可以用树剖+线段树对路径进行修改了 然后顺便注意在上面这种转化之后,树剖的时候不能搞$LCA$ 然后是几个注意点 ...
- 洛谷 P3373 【模板】线段树 2
洛谷 P3373 [模板]线段树 2 洛谷传送门 题目描述 如题,已知一个数列,你需要进行下面三种操作: 将某区间每一个数乘上 xx 将某区间每一个数加上 xx 求出某区间每一个数的和 输入格式 第一 ...
- BZOJ_2238_Mst_树剖+线段树
BZOJ_2238_Mst_树剖+线段树 Description 给出一个N个点M条边的无向带权图,以及Q个询问,每次询问在图中删掉一条边后图的最小生成树.(各询问间独立,每次询问不对之后的询问产生影 ...
- BZOJ_4551_[Tjoi2016&Heoi2016]树_树剖+线段树
BZOJ_4551_[Tjoi2016&Heoi2016]树_树剖+线段树 Description 在2016年,佳媛姐姐刚刚学习了树,非常开心.现在他想解决这样一个问题:给定一颗有根树(根为 ...
- BZOJ_2157_旅游_树剖+线段树
BZOJ_2157_旅游_树剖+线段树 Description Ray 乐忠于旅游,这次他来到了T 城.T 城是一个水上城市,一共有 N 个景点,有些景点之间会用一座桥连接.为了方便游客到达每个景点但 ...
- 【BZOJ5210】最大连通子块和 树剖线段树+动态DP
[BZOJ5210]最大连通子块和 Description 给出一棵n个点.以1为根的有根树,点有点权.要求支持如下两种操作: M x y:将点x的点权改为y: Q x:求以x为根的子树的最大连通子块 ...
- [LNOI2014]LCA(树剖+线段树)
\(\%\%\% Fading\) 此题是他第一道黑题(我的第一道黑题是蒲公英) 一直不敢开,后来发现是差分一下,将询问离线,树剖+线段树维护即可 \(Code\ Below:\) #include ...
- [CF1007D]Ants[2-SAT+树剖+线段树优化建图]
题意 我们用路径 \((u, v)\) 表示一棵树上从结点 \(u\) 到结点 \(v\) 的最短路径. 给定一棵由 \(n\) 个结点构成的树.你需要用 \(m\) 种不同的颜色为这棵树的树边染色, ...
- LOJ#3088. 「GXOI / GZOI2019」旧词(树剖+线段树)
题面 传送门 题解 先考虑\(k=1\)的情况,我们可以离线处理,从小到大对于每一个\(i\),令\(1\)到\(i\)的路径上每个节点权值增加\(1\),然后对于所有\(x=i\)的询问查一下\(y ...
- BZOJ3531-[Sdoi2014]旅行(树剖+线段树动态开点)
传送门 完了今天才知道原来线段树的动态开点和主席树是不一样的啊 我们先考虑没有宗教信仰的限制,那么就是一个很明显的树剖+线段树,路径查询最大值以及路径和 然后有了宗教信仰的限制该怎么做呢? 先考虑暴力 ...
随机推荐
- poj——3177Redundant Paths
poj——3177Redundant Paths 洛谷—— P2860 [USACO06JAN]冗余路径Redundant Paths Time Limit: 1000MS Memory ...
- [Bzoj1297][Scoi2009 ]迷路 (矩阵乘法 + 拆点)
1297: [SCOI2009]迷路 Time Limit: 10 Sec Memory Limit: 162 MBSubmit: 1385 Solved: 993[Submit][Status] ...
- codeforces 873E(枚举+rmq)
题意 有n(n<=3000)个人参与acm比赛,每个人都有一个解题数,现在要决定拿金牌的人数cnt1,拿银牌的人数cnt2,拿铜牌的人数cnt3,各自对应一个解题数区间[d1,c1],[d2,c ...
- css三大布局
标准流: 从左到右,从上到下块级元素独占一行,行内元素碰到父盒子边缘换行 浮动: 特点 1 元素浮动之后不占据原来的位置(脱标),变成立体,下面可以有东西,只影响下面的 2 浮动的盒子在一行上显示 3 ...
- ios开发 MPMoviePlayerController 视频播放器
项目中用到视频播放功能, 写点视频基础部分 MPMoviePlayerController是通过MediaPlayer.frame引入的,可用于播放在iOS支持的所有格式的视频,用起来很简单!!! M ...
- 基于RTP的h.264视频传输系统设计(一)
一.H.264 的层次介绍 H.264 定义三个层次,每一个层次支持一组特定的编码功能.而且按照各个层次指定所指定的功能.基础层次(baselineprofile)支持I 帧和 P 帧[1]的帧内和帧 ...
- Zookeeper中的FastLeaderElection选举算法简述
Zookeeper是一个开源的分布式应用协调项目, 当中为了保证各节点的协同工作,Zookeeper在工作时须要有一个Leader. 而Leader是怎样被选举出来的?Zookeep中使用的缺省算法称 ...
- 安装和配置Apache-tomcat
https://tomcat.apache.org/download-90.cgi 我随便下载了一个,而且解压了 我把路径:G:\php\apache-tomcat-9.0.6\bin 放入path, ...
- 在XX公司工作第二天,维护已有代码
根据<C++ More Exception>所述的规则: Rule #1: Never write using-directives in header files. Rule #2: N ...
- 微信通过openID发送消息/后台post、get提交并接收数据 C# .NET 配置404,500等错误信息 连接字符串
微信通过openID发送消息/后台post.get提交并接收数据 控制器:下面是post发送消息(微信不支持从前台发送数据,之前试过,报错,需要跨域,跨域的问题解决后还不行,最后发现之后后端提交 ...