题目戳我

\(\text{Solution:}\)

这题不要把思想局限到线段树上……这题大意就是求路径经过的值中\(x\)的出现性问题。

最开始的想法是值域线段树……看了题解发现直接\(vector\)加二分即可\(O(n\log^2 n)\)解决。

思路:

用\(vector\)存下颜色\(i\)所出现的所有节点,对每一个\(vector\)排序后,考虑跳链的过程中二分第一个大于链头\(dfs\)序的点并判断它是不是在当前查询区间的范围内。最终复杂度是跳链的\(log\)和二分的\(\log.\)

#include<bits/stdc++.h>
using namespace std;
const int MAXN=2e5+10;
int top[MAXN],id[MAXN],rk[MAXN],son[MAXN],siz[MAXN],pa[MAXN];
int head[MAXN],tot,cnt,rt,n,m,dep[MAXN],ls[MAXN],rs[MAXN],val[MAXN];
struct E{int nxt,to;}e[MAXN];
vector<int>v[MAXN];
inline void add(int x,int y){e[++tot]=(E){head[x],y};head[x]=tot;}
void dfs1(int x,int fa){
pa[x]=fa,siz[x]=1,dep[x]=dep[fa]+1;
for(int i=head[x];i;i=e[i].nxt){
int j=e[i].to;
if(j==fa)continue;
dfs1(j,x);siz[x]+=siz[j];
if(siz[j]>siz[son[x]])son[x]=j;
}
}
void dfs2(int x,int t){
top[x]=t,rk[id[x]=++cnt]=x;
if(!son[x])return;
dfs2(son[x],t);
for(int i=head[x];i;i=e[i].nxt){
int j=e[i].to;
if(j!=pa[x]&&j!=son[x])dfs2(j,j);
}
}
void dfs3(int x){
v[val[x]].push_back(id[x]);
for(int i=head[x];i;i=e[i].nxt){
int j=e[i].to;
if(j==pa[x])continue;
dfs3(j);
}
}
void solve(int x,int y,int c){
int fg=0;
while(top[x]!=top[y]){
if(dep[top[x]]<dep[top[y]])swap(x,y);
vector<int>::iterator it=lower_bound(v[c].begin(),v[c].end(),id[top[x]]);
if(it!=v[c].end()&&*it<=id[x])fg=1;
x=pa[top[x]];
}
if(dep[x]<dep[y])swap(x,y);
vector<int>::iterator it=lower_bound(v[c].begin(),v[c].end(),id[y]);
if(it!=v[c].end()&&*it<=id[x])fg=1;
printf("%d",fg);
}
int main(){
scanf("%d%d",&n,&m);
for(int i=1;i<=n;++i)scanf("%d",&val[i]);
for(int i=1;i<n;++i){
int x,y;
scanf("%d%d",&x,&y);
add(x,y);add(y,x);
}
dfs1(1,0);dfs2(1,1);dfs3(1);
for(int i=1;i<=n;++i)sort(v[i].begin(),v[i].end());
for(int i=1;i<=m;++i){
int x,y,z;
scanf("%d%d%d",&x,&y,&z);
solve(x,y,z);
}
return 0;
}

最新文章

  1. webkit浏览器css设置滚动条
  2. Activity 跳转动画 全局定义
  3. Unity之定时调用
  4. 如何在myeclipse8.5中使用maven
  5. The working copy xxxx needs to be upgraded to Subversion 1.7.
  6. 【solr专题之一】Solr快速入门
  7. 【4】项目结构+基本的Tornado服务
  8. PHP的MySQL扩张:MySQL数据库概述
  9. node.js使用scp2来进行scp操作
  10. Java Map 及相应的一些操作总结
  11. 解决mysql乱码问题
  12. Jquery中AJAX参数详细(1)-转
  13. [原创]Studio 3T mogodb数据库工具使用介绍
  14. 更改mysql 和jinkins目录
  15. leetcode — two-sum-iii-data-structure-design
  16. AirSim
  17. poj1142
  18. Windows10中注册 regsvr32 xxx.ocx报错but the call to DIIRegisterServer failed with error code 0x80040200
  19. W1002 Symbol &#39;Create&#39; is specific to a platform
  20. vue组件系统

热门文章

  1. 微信小程序|小游戏
  2. P1082 同余方程(拓展欧几里德)
  3. 在centos6.5下搭建lnmp
  4. 18_Python常用的模块中的某个方法
  5. 教会舍友玩 Git (再也不用担心他的学习)
  6. Spring-代理模式
  7. java实现内网通信
  8. 如何《快速搭建LAMP环境》
  9. md5命令
  10. Spring系列之初识Spring Spring概述