亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 學院 > 開發設計 > 正文

Manthan, Codefest 16 G. Yash And Trees(dfs序,bitset,線段樹,好題)

2019-11-10 18:12:05
字體:
來源:轉載
供稿:網友

題目鏈接G. Yash And Treestime limit per test4 secondsmemory limit per test512 megabytesinputstandard inputoutputstandard output

Yash loves playing with trees and gets especially excited when they have something to do with PRime numbers. On his 20th birthday he was granted with a rooted tree of n nodes to answer queries on. Hearing of prime numbers on trees, Yash gets too intoxicated with excitement and asks you to help out and answer queries on trees for him. Tree is rooted at node 1. Each node i has some value aiassociated with it. Also, integer m is given.

There are queries of two types:

for given node v and integer value x, increase all ai in the subtree of node v by value xfor given node v, find the number of prime numbers p less than m, for which there exists a node u in the subtree of v and a non-negative integer value k, such that au?=?p?+?m·k.Input

The first of the input contains two integers n and m (1?≤?n?≤?100?000,?1?≤?m?≤?1000) — the number of nodes in the tree and value mfrom the problem statement, respectively.

The second line consists of n integers ai (0?≤?ai?≤?109) — initial values of the nodes.

Then follow n?-?1 lines that describe the tree. Each of them contains two integers ui and vi (1?≤?ui,?vi?≤?n) — indices of nodes connected by the i-th edge.

Next line contains a single integer q (1?≤?q?≤?100?000) — the number of queries to proceed.

Each of the last q lines is either 1 v x or 2 v (1?≤?v?≤?n,?0?≤?x?≤?109), giving the query of the first or the second type, respectively. It's guaranteed that there will be at least one query of the second type.

Output

For each of the queries of the second type print the number of suitable prime numbers.

Examplesinput
8 203 7 9 8 4 11 7 31 21 33 44 54 64 75 842 11 1 12 52 4output
311input
5 108 7 5 1 01 22 31 52 431 1 01 1 22 2output
2

題意

給你一棵樹,n個結點,再給出一個數m(1?≤?m?≤?1000)

每個點有一個點權

有兩個操作

1 x v 使得x子樹里面的所有點的權值加v

2 x 查詢x的子樹里面所有點的權值中有多少個滿足p+k*m,其中p是小于m的素數,求出p的個數。

題解:

對于樹上對一個結點子樹的操作,可以采用dfs序。然后用線段樹存儲,對于線段樹的每個節點,維護區間出現過哪些數??梢杂胋itset實現。

更新操作,就直接讓這個bitset循環移動就好了,注意循環移動可以拆成兩個步驟,一個向右邊移動(x%m),一個向左邊移動(m-x),然后兩個并起來就好了

查詢操作,就最后得到那個區間的bitset和m以內的素數表&一下就好了。

#include<iostream>#include<cstdio>#include<algorithm>#include<cstring>#include<vector>#include<queue>#include<stack>#include<bitset>using namespace std;#define rep(i,a,n) for (int i=a;i<n;i++)#define per(i,a,n) for (int i=n-1;i>=a;i--)#define pb push_back#define fi first#define se secondtypedef vector<int> VI;typedef long long ll;typedef pair<int,int> PII;const int inf=0x3fffffff;const ll mod=1000000007;const int maxn=100000+100;const int maxm=1000+5;typedef bitset<maxm> S;int head[maxn];int n,m;struct edge{    int from,to,next;}e[maxn*2];   //int tol=0;void add(int u,int v){    e[++tol].to=v,e[tol].next=head[u],head[u]=tol;}struct node{    int l,r;    int lazy,tag;    S sum;}seg[maxn*4];int c[maxn];void build(int i,int l,int r){    seg[i].l=l,seg[i].r=r,seg[i].sum.reset(),seg[i].lazy=seg[i].tag=0;    if(l==r)    {        seg[i].sum[c[l]]=1;        return;    }    int m=(l+r)/2;    build(i*2,l,m),build(i*2+1,m+1,r);    seg[i].sum=seg[i*2].sum|seg[i*2+1].sum;}void pushdown(int i){    if(seg[i].l!=seg[i].r)    {        int v=seg[i].tag;        S t1=seg[i*2].sum,t2=seg[i*2+1].sum;        seg[i*2].sum=(t1<<v)|(t1>>(m-v)),seg[i*2+1].sum=(t2<<v)|(t2>>(m-v));        seg[i*2].tag=(seg[i*2].tag+v)%m,seg[i*2+1].tag=(seg[i*2+1].tag+v)%m;        seg[i*2].lazy=seg[i*2+1].lazy=1;        seg[i].lazy=seg[i].tag=0;    }}void update(int i,int l,int r,int v){    if(seg[i].l==l&&seg[i].r==r)    {        if(seg[i].lazy)            seg[i].tag+=v,seg[i].tag%=m;        else        {            seg[i].tag=v;            seg[i].lazy=1;        }        S t=seg[i].sum;        seg[i].sum=(seg[i].sum<<v)|(seg[i].sum>>(m-v));        return;    }    if(seg[i].lazy)        pushdown(i);    int m=(seg[i].l+seg[i].r)/2;    if(r<=m) update(i*2,l,r,v);    else if(l>m) update(i*2+1,l,r,v);    else    {        update(i*2,l,m,v),update(i*2+1,m+1,r,v);    }    seg[i].sum=seg[i*2].sum|seg[i*2+1].sum;}S query(int i,int l,int r){    if(seg[i].l==l&&seg[i].r==r)    {        return seg[i].sum;    }    if(seg[i].lazy)        pushdown(i);    int m=(seg[i].l+seg[i].r)/2;    if(r<=m) return query(i*2,l,r);    else if(l>m) return query(i*2+1,l,r);    else return query(i*2,l,m)|query(i*2+1,m+1,r);}int st[maxn],en[maxn];int a[maxn];int cnt=0;void dfs(int u,int f)       //dfs序{    st[u]=++cnt;    c[cnt]=a[u];    for(int i=head[u];i;i=e[i].next)    {        int v=e[i].to;        if(v==f) continue;        dfs(v,u);    }    en[u]=cnt;}int vis[maxn];S pri;void init(){    memset(vis,0,sizeof(vis));    pri.reset();    for(int i=2;i<m;i++)       //預處理m以內的素數,儲存在pri中    {        if(vis[i]) continue;        pri[i]=1;        for(int j=i*i;j<m;j+=i)            vis[j]=1;    }}int main(){    scanf("%d%d",&n,&m);    init();    rep(i,1,n+1) scanf("%d",&a[i]),a[i]%=m;    rep(i,1,n)    {        int u,v;        scanf("%d%d",&u,&v);        add(u,v),add(v,u);    }    dfs(1,-1);    build(1,1,n);    int q;    scanf("%d",&q);    while(q--)    {        int op,u,v;        scanf("%d",&op);        if(op==1)        {            scanf("%d%d",&u,&v);            v%=m;            update(1,st[u],en[u],v);        }        else        {            scanf("%d",&u);            S res=query(1,st[u],en[u]);            int ans=(res&pri).count();   //            printf("%d/n",ans);        }    }    return 0;}


發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
国产精品爽黄69| 日韩在线中文字幕| 91国偷自产一区二区三区的观看方式| 中文字幕久精品免费视频| 欧美亚洲国产成人精品| 成人妇女免费播放久久久| 亚洲欧美精品一区| 亚洲黄色免费三级| 成人免费视频网| 亚洲欧美资源在线| 九色成人免费视频| 日本高清不卡在线| 久久久噜噜噜久久中文字免| 精品一区精品二区| 亚洲aⅴ男人的天堂在线观看| 国产成人一区二区三区小说| 欧美日韩国产一中文字不卡| 国产精品69av| 91国内在线视频| 综合激情国产一区| 福利一区福利二区微拍刺激| 久久久久久com| 91免费人成网站在线观看18| 精品亚洲夜色av98在线观看| 九色成人免费视频| www.xxxx欧美| 91国内免费在线视频| 国产成人高潮免费观看精品| 欧美高清不卡在线| 久久精品人人做人人爽| 国产91精品高潮白浆喷水| 亚洲国产精久久久久久久| 亚洲精品日韩欧美| 欧美成人在线免费视频| 5278欧美一区二区三区| 欧美激情精品久久久久| 亚洲香蕉av在线一区二区三区| 成人精品网站在线观看| 日韩欧美成人区| 国产97色在线| 国产97色在线| 成人免费网站在线观看| 5566日本婷婷色中文字幕97| 欧美午夜精品久久久久久久| 欧美性精品220| 91精品国产91久久久久久吃药| 欧美大片欧美激情性色a∨久久| 日本成人免费在线| 日韩美女av在线免费观看| 久久久久久久一区二区三区| 51视频国产精品一区二区| 国产亚洲一区二区精品| 日韩av123| 日本久久亚洲电影| 国产精品午夜国产小视频| 亚洲国产免费av| 日韩美女在线看| 国产精彩精品视频| 国产精品久久久久免费a∨| 国产精彩精品视频| 亚洲性av在线| 亚洲精品美女久久久久| 亚洲片在线观看| 亚洲xxxxx| 国产精品欧美在线| 国产精品久久久久久久久| 亚洲国产日韩欧美综合久久| 久久99精品国产99久久6尤物| 久久影视电视剧免费网站清宫辞电视| 日韩精品视频中文在线观看| 91九色在线视频| 第一福利永久视频精品| 欧美激情精品久久久久久蜜臀| 精品国内产的精品视频在线观看| 欧美成人黑人xx视频免费观看| 亚洲精品一区二区在线| 亚洲专区中文字幕| 国产精品揄拍500视频| 欧美色另类天堂2015| 久久精品成人动漫| 91亚洲国产成人精品性色| 国产精品久久久久av| 欧美性极品xxxx做受| 亚洲最大福利网站| 国产日韩欧美在线播放| 97色在线观看| 国产精品视频网| 国产午夜精品视频免费不卡69堂| 久久久久久久久久久网站| 国产免费一区二区三区在线能观看| 97久久超碰福利国产精品…| 欧美激情精品久久久久久| 亚洲一区999| 国产福利精品在线| 精品少妇v888av| 久久影院资源站| 91免费看国产| 久久久久久久久综合| 日韩av影片在线观看| 久久久久久免费精品| 91国产美女视频| 欧美在线播放视频| 亚洲视频电影图片偷拍一区| 欧美成人手机在线| 日韩欧美中文免费| 日韩视频免费在线| 国产最新精品视频| 最近的2019中文字幕免费一页| 欧美丝袜美女中出在线| 亚洲一区免费网站| 欧美激情日韩图片| 亚洲精品国产美女| 九九综合九九综合| 精品亚洲夜色av98在线观看| 色噜噜亚洲精品中文字幕| 日韩在线免费视频观看| 少妇高潮久久77777| 久久综合电影一区| 亚洲免费精彩视频| 88国产精品欧美一区二区三区| 欧美激情视频一区| 久久av资源网站| 久久综合免费视频影院| 成人久久18免费网站图片| www.日韩欧美| 国产中文日韩欧美| 日本久久久久久久| 久久夜色精品亚洲噜噜国产mv| 日韩一区在线视频| 国产99视频在线观看| 色综合久久悠悠| 一本色道久久88亚洲综合88| 亚洲一区二区福利| 久久久久久亚洲精品不卡| 国产成人精品国内自产拍免费看| 91精品久久久久久久久久入口| 亚洲欧洲美洲在线综合| 国产一区二区色| 亚洲国产精久久久久久久| 日韩不卡中文字幕| 亚洲美女自拍视频| 91久久久精品| 日韩高清欧美高清| 欧美天天综合色影久久精品| 91亚洲国产成人精品性色| 国产成人自拍视频在线观看| 中文字幕日韩有码| 日韩国产精品视频| 日韩精品视频在线免费观看| 国产脚交av在线一区二区| 国模私拍视频一区| 97在线视频观看| 欧美在线观看网址综合| 国产在线观看91精品一区| 欧美日韩亚洲精品一区二区三区| 久久久伊人欧美| 成人美女av在线直播| 色综合久久88| 欧美成人免费播放| 日韩中文有码在线视频| 国产精品欧美一区二区三区奶水| 亚洲成人教育av| 久久久精品日本| 91色在线观看|