伍佰目录 短网址
  当前位置:海洋目录网 » 站长资讯 » 站长资讯 » 文章详细 订阅RssFeed

CF375D Tree and Queries

来源:本站原创 浏览:136次 时间:2021-10-10
题意翻译

给出一棵 n 个结点的树,每个结点有一个颜色 c i 。 询问 q 次,每次询问以 v 结点为根的子树中,出现次数 ≥k 的颜色有多少种。树的根节点是1。

感谢@elijahqi 提供的翻译

题目描述

You have a rooted tree consisting of n n n vertices. Each vertex of the tree has some color. We will assume that the tree vertices are numbered by integers from 1 to n n n . Then we represent the color of vertex v v v as cv c_{v} cv . The tree root is a vertex with number 1.

In this problem you need to answer to m m m queries. Each query is described by two integers vj,kj v_{j},k_{j} vj,kj . The answer to query vj,kj v_{j},k_{j} vj,kj is the number of such colors of vertices x x x , that the subtree of vertex vj v_{j} vj contains at least kj k_{j} kj vertices of color x x x .

You can find the definition of a rooted tree by the following link: http://en.wikipedia.org/wiki/Tree\_(graph\_theory).

输入输出格式

输入格式:

The first line contains two integers n n n and m m m $ (2<=n<=10^{5}; 1<=m<=10^{5}) $ . The next line contains a sequence of integers c1,c2,...,cn c_{1},c_{2},...,c_{n} c1,c2,...,cn (1<=ci<=105) (1<=c_{i}<=10^{5}) (1<=ci<=105) . The next n−1 n-1 n−1 lines contain the edges of the tree. The i i i -th line contains the numbers ai,bi a_{i},b_{i} ai,bi $ (1<=a_{i},b_{i}<=n; a_{i}≠b_{i}) $ — the vertices connected by an edge of the tree.

Next m m m lines contain the queries. The j j j -th line contains two integers vj,kj v_{j},k_{j} vj,kj $ (1<=v_{j}<=n; 1<=k_{j}<=10^{5}) $ .

输出格式:

Print m m m integers — the answers to the queries in the order the queries appear in the input.

输入输出样例

输入样例#1: 

8 51 2 2 3 3 2 3 31 21 52 32 45 65 75 81 21 31 42 35 3

输出样例#1: 

22101

输入样例#2: 

4 11 2 3 41 22 33 41 1

输出样例#2: 

4
说明

A subtree of vertex v v v in a rooted tree with root r r r is a set of vertices $ {u :di��ɡ����,���յ���st(r,v)+dist(v,u)=dist(r,u)} $ . Where dist(x,y) dist(x,y) dist(x,y) is the length (in edges) of the shortest path between vertices x x x and y y y .

 

Solution:

   本题树上莫队。

  求子树颜色个数,可以直接弄出dfs序,统计每个子树的入栈时间$inc$和$ouc$,然后对于询问变为dfs序上的区间颜色数查询,直接莫队就好了。

代码:

/*Code by 520 -- 10.19*/#include#define il inline#define ll long long#define RE register#define For(i,a,b) for(RE int (i)=(a);(i)<=(b);(i)++)#define Bor(i,a,b) for(RE int (i)=(b);(i)>=(a);(i)--)using namespace std;const int N=200005;int n,m,to[N],net[N],h[N],cnt,a[N],bl[N],c[N];int rc,dfn[N],inc[N],ouc[N],sum[N],ans[N];struct node{    int l,r,k,id;    bool operator < (const node &a) const {return bl[l]==bl[a.l]?r<a.r:l<a.l;}}t[N];int gi(){    int a=0;char x=getchar();    while(x<'0'||x>'9') x=getchar();    while(x>='0'&&x<='9') a=(a<<3)+(a<<1)+(x^48),x=getchar();    return a;}il void Add(int u,int v){to[++cnt]=v,net[cnt]=h[u],h[u]=cnt;}void dfs(int u,int lst){    dfn[++rc]=u,inc[u]=rc;    for(RE int i=h[u];i;i=net[i])        if(to[i]!=lst) dfs(to[i],u);    ouc[u]=rc;}il void add(int x){sum[++c[a[x]]]++;}il void del(int x){sum[c[a[x]]--]--;}int main(){    n=gi(),m=gi(); int blo=sqrt(n),u,v;    For(i,1,n) a[i]=gi(),bl[i]=(i-1)/blo+1;    For(i,2,n) u=gi(),v=gi(),Add(u,v),Add(v,u);    dfs(1,0);    For(i,1,m) u=gi(),v=gi(),t[i]=node{inc[u],ouc[u],v,i};    sort(t+1,t+m+1);    for(RE int i=1,l=1,r=0;i<=m;i++){        while(l<t[i].l) del(dfn[l]),l++;        while(l>t[i].l) --l,add(dfn[l]);        while(r<t[i].r) ++r,add(dfn[r]);        while(r>t[i].r) del(dfn[r]),r--;        ans[t[i].id]=sum[t[i].k];        }    For(i,1,m) printf("%d\n",ans[i]);    return 0;}

 

 

 

 

 

 

 

  推荐站点

  • At-lib分类目录At-lib分类目录

    At-lib网站分类目录汇集全国所有高质量网站,是中国权威的中文网站分类目录,给站长提供免费网址目录提交收录和推荐最新最全的优秀网站大全是名站导航之家

    www.at-lib.cn
  • 中国链接目录中国链接目录

    中国链接目录简称链接目录,是收录优秀网站和淘宝网店的网站分类目录,为您提供优质的网址导航服务,也是网店进行收录推广,站长免费推广网站、加快百度收录、增加友情链接和网站外链的平台。

    www.cnlink.org
  • 35目录网35目录网

    35目录免费收录各类优秀网站,全力打造互动式网站目录,提供网站分类目录检索,关键字搜索功能。欢迎您向35目录推荐、提交优秀网站。

    www.35mulu.com
  • 就要爱网站目录就要爱网站目录

    就要爱网站目录,按主题和类别列出网站。所有提交的网站都经过人工审查,确保质量和无垃圾邮件的结果。

    www.912219.com
  • 伍佰目录伍佰目录

    伍佰网站目录免费收录各类优秀网站,全力打造互动式网站目录,提供网站分类目录检索,关键字搜索功能。欢迎您向伍佰目录推荐、提交优秀网站。

    www.wbwb.net