[SPOJ]Count on a tree II(树上莫队)
树上莫队模板题。
使用欧拉序将树上路径转化为普通区间。
之后莫队维护即可。不要忘记特判LCA
#include<iostream>
#include<cstdio>
#include<cstring>
#include<cmath>
#include<algorithm>
#define N 200005
using namespace std;
int read()
{
int x=,f=;char ch=getchar();
while(ch<''||ch>''){if(ch=='-')f=-;ch=getchar();}
while(ch>=''&&ch<=''){x=(x<<)+(x<<)+(ch^);ch=getchar();}
return x*f;
}
int n,m,val[N],inp[N],cnt[N],v[N],nxt[N],head[N],cntt,tot,siz,ord[N],ncnt,fir[N],lst[N];
int fa[N][],dep[N],now,l=,r=,ans[N],vis[N];
struct node
{
int l,r,x,lca;
}q[N];
bool cmp(node a,node b)
{
if(a.l/siz!=b.l/siz)return a.l/siz<b.l/siz;
return a.r<b.r;
}
void add(int a,int b)
{
v[++cntt]=b;
nxt[cntt]=head[a];
head[a]=cntt;
}
void dfs1(int x,int f)
{
dep[x]=dep[f]+;
for(int i=;i<=;i++)fa[x][i+]=fa[fa[x][i]][i];
for(int i=head[x];i;i=nxt[i])
{
if(v[i]==f)continue;
fa[v[i]][]=x;
dfs1(v[i],x);
}
}
int lca(int x,int y)
{
if(dep[x]<dep[y])swap(x,y);
for(int i=;i>=;i--)
{
if(dep[fa[x][i]]>=dep[y])x=fa[x][i];
if(x==y)return x;
}
for(int i=;i>=;i--)
{
if(fa[x][i]!=fa[y][i])x=fa[x][i],y=fa[y][i];
}
return fa[x][];
}
void dfs2(int x,int f)
{
ord[++ncnt]=x;
fir[x]=ncnt;
for(int i=head[x];i;i=nxt[i])
{
if(v[i]==f)continue;
dfs2(v[i],x);
}
ord[++ncnt]=x;
lst[x]=ncnt;
}
void work(int pos)
{
if(vis[pos])now-=!--cnt[val[pos]];
else now+=!cnt[val[pos]]++;
vis[pos]^=;
}
int main()
{
n=read();m=read();
for(int i=;i<=n;i++)val[i]=inp[i]=read();
sort(inp+,inp+n+);
tot=unique(inp+,inp+n+)-inp-;
for(int i=;i<=n;i++)val[i]=lower_bound(inp+,inp+tot+,val[i])-inp;
for(int x,y,i=;i<n;i++)
{
x=read();y=read();
add(x,y);add(y,x);
}
dfs1(,);dfs2(,);
for(int i=;i<=m;i++)
{
int ll=read(),rr=read(),LCA=lca(ll,rr);
if(fir[ll]>fir[rr])swap(ll,rr);
if(ll==LCA)
{
q[i].l=fir[ll];
q[i].r=fir[rr];
}
else
{
q[i].l=lst[ll];
q[i].r=fir[rr];
q[i].lca=LCA;
}
q[i].x=i;
}
siz=sqrt(ncnt);
sort(q+,q+m+,cmp);
for(int i=;i<=m;i++)
{
int ll=q[i].l,rr=q[i].r,Lca=q[i].lca;
while(l<ll)work(ord[l++]);
while(l>ll)work(ord[--l]);
while(r<rr)work(ord[++r]);
while(r>rr)work(ord[r--]);
if(Lca)work(Lca);
ans[q[i].x]=now;
if(Lca)work(Lca);
}
for(int i=;i<=m;i++)printf("%d\n",ans[i]);
return ;
}
[SPOJ]Count on a tree II(树上莫队)的更多相关文章
- spoj COT2 - Count on a tree II 树上莫队
题目链接 http://codeforces.com/blog/entry/43230树上莫队从这里学的, 受益匪浅.. #include <iostream> #include < ...
- SP10707 COT2 - Count on a tree II (树上莫队)
大概学了下树上莫队, 其实就是在欧拉序上跑莫队, 特判lca即可. #include <iostream> #include <algorithm> #include < ...
- SP10707 COT2 - Count on a tree II [树上莫队学习笔记]
树上莫队就是把莫队搬到树上-利用欧拉序乱搞.. 子树自然是普通莫队轻松解决了 链上的话 只能用树上莫队了吧.. 考虑多种情况 [X=LCA(X,Y)] [Y=LCA(X,Y)] else void d ...
- SPOJ COT2 Count on a tree II 树上莫队算法
题意: 给出一棵\(n(n \leq 4 \times 10^4)\)个节点的树,每个节点上有个权值,和\(m(m \leq 10^5)\)个询问. 每次询问路径\(u \to v\)上有多少个权值不 ...
- P4074 [WC2013]糖果公园 树上莫队带修改
题目链接 Candyland 有一座糖果公园,公园里不仅有美丽的风景.好玩的游乐项目,还有许多免费糖果的发放点,这引来了许多贪吃的小朋友来糖果公园游玩. 糖果公园的结构十分奇特,它由 nn 个游览点构 ...
- 【SPOJ】Count On A Tree II(树上莫队)
[SPOJ]Count On A Tree II(树上莫队) 题面 洛谷 Vjudge 洛谷上有翻译啦 题解 如果不在树上就是一个很裸很裸的莫队 现在在树上,就是一个很裸很裸的树上莫队啦. #incl ...
- SPOJ COT2 - Count on a tree II(LCA+离散化+树上莫队)
COT2 - Count on a tree II #tree You are given a tree with N nodes. The tree nodes are numbered from ...
- 「日常训练&知识学习」莫队算法(二):树上莫队(Count on a tree II,SPOJ COT2)
题意与分析 题意是这样的,给定一颗节点有权值的树,然后给若干个询问,每次询问让你找出一条链上有多少个不同权值. 写这题之前要参看我的三个blog:Codeforces Round #326 Div. ...
- SPOJ COT2 Count on a tree II (树上莫队,倍增算法求LCA)
题意:给一个树图,每个点的点权(比如颜色编号),m个询问,每个询问是一个区间[a,b],图中两点之间唯一路径上有多少个不同点权(即多少种颜色).n<40000,m<100000. 思路:无 ...
随机推荐
- APIO2019 题解
APIO2019 题解 T1 奇怪装置 题目传送门 https://loj.ac/problem/3144 题解 很容易发现,这个东西一定会形成一个环.我们只需要求出环的长度就解决了一切问题. 设环的 ...
- SDOI2010代码拍卖会 (计数类DP)
P2481 SDOI2010代码拍卖会 $ solution: $ 这道题调了好久好久,久到都要放弃了.洛谷的第五个点是真的强,简简单单一个1,调了快4个小时! 这道题第一眼怎么都是数位DP,奈何数据 ...
- Python 序列化 pickle/cPickle模块
Python 序列化 pickle/cPickle模块 2013-10-17 Posted by yeho Python序列化的概念很简单.内存里面有一个数据结构,你希望将它保存下来,重用,或者发送给 ...
- tomcat的内存配置
WEB站点在跑安全测试时,跑一会儿就连接不上,考虑是否是tomcat内存溢出问题. Linux环境,修改Tomcat的内存配置: 修改bin/catalina.sh文件,在cygwin=false前面 ...
- LA 4327 Parade(单调队列优化dp)
题目链接: 题目大意(摘自刘汝佳<<算法竞赛入门经典--训练指南>>):F城是由n+1条横向路和m+1条竖向路组成.你的任务是从最南边的路走到最北边的路,使得走过的路上的高兴值 ...
- [luogu]P1600 天天爱跑步[LCA]
[luogu]P1600 [NOIP 2016]天天爱跑步 题目描述 小c同学认为跑步非常有趣,于是决定制作一款叫做<天天爱跑步>的游戏.«天天爱跑步»是一个养成类游戏,需要玩家每天按时上 ...
- java导入ldif文件
网上导入ldif文件的方式都是基于命令,或者相应工具如LDAP Browser \Editor v2.8.2. 但用java去实现这样的功能好像网上很少,于是我参照相应的开源代码并整理了一下,亲自测试 ...
- Qt中用QuaZip来压缩和解压缩文件
1.简介 QuaZIP是使用Qt,C++对ZLIB进行简单封装的用于压缩ZIP以及解压缩ZIP的开源库.如果你的Qt项目当中用到了压缩以及解压缩ZIP的话你可以考虑选择使用它. 官方主页:http:/ ...
- 三十二、python操作XML文件
'''XML:模块 xml总结 1.解析 str 文件 tree,ElementTree,type root,Element,type2.操作 Element: tag,text,find,iter, ...
- MongoDB学习【一】—MongoDB简介和安装
一.MongoDB简介 1.MongoDB是什么 MongoDB是一款强大.灵活.且易于扩展的通用型数据库,MongoDB 是由C++语言编写的,是一个基于分布式文件存储的开源数据库系统. 在高负载的 ...