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

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

某次模擬考試day2t3 菊菊的數據結構

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

【題目描述】菊菊是一個碼農,他很喜歡碼一些高(e)級(xin)數據結構。有一天,菊菊在打網賽時遇到了 wfj。wfj 覺得他很有前途,可以做下一代碼農大神。于是乎,wfj 給菊菊出了一道題,來檢驗一下菊菊的代碼能力:這是一個簡單的數據結構題,你只需在樹上維護如下幾個簡單操作:type=1:樹上單點修改,給定 x,v,把 x 的值改為 v。type=2:樹上子樹修改,給定 x,v,把 x 子樹上的所有數加上 v。type=3:樹上路徑修改,給定 x,y,v,把 x 到 y 路徑上的所有數加上 v。type=4:樹上單點查詢,給定 x,查詢 x 的值。type=5:樹上子樹查詢,給定 x,查詢子樹 x 的和。type=6:樹上路徑查詢,給定 x,y,查詢 x 到 y 路徑上數的和。wfj 想了很久,覺得這題太容易了,沒有任何意義。所以,在上面這些操作完成以后,他還要求菊菊完成另外一些操作:type=7:樹上子樹查詢區間第 k 小,給定 x,k,求 x 子樹上第 k 小值。type=8:樹上子樹查詢比給定數小的數的個數,給定 x,k,求 x 子樹上比 k 小的數的個數。type=9:樹上路徑查詢區間第 k 小,給定 x,y,k(huaji.jpg),求 x 到 y 路徑上的區間第 k 小。type=10:樹上路徑查詢比給定數小的數的個數,給定 x,y,k,求 x 到 y 路徑上比 k 小的數的個數。wfj 又想了很久,覺得這題可以了。然而這時,菊菊對他說:“這也太容易了吧!我半小時就能 AC!”于是 wfj 怒了。他想:這個 sb,我再加一問,不信他寫 得出。于是,wfj加了最后一問:對于這棵樹,請求出這棵樹中<=k 的路徑條數,其中,k 為給定值。菊菊是一個智商特別高的編程天才,他身上帶了電腦,但他這回做不出來了,所以他委托你——一位植樹工人來完成這個游戲。你能幫幫他嗎?【輸入數據】第一行包括兩個整數 N,表示這顆樹的結點數。接下來一行包括 N 個整數 Ai,表示 N 個結點初始權值。接下來有 N-1 行,每行兩個數 x,y,表示 x 和 y 之間有邊相連。接下來一行包括一個整數 M1,表示第一問的詢問數。接下來 M1 行每行包括一個數 type,后接幾個數:type=1:輸入 x,v。type=2:輸入 x,v。type=3:輸入 x,y,v。type=4:輸入 x。type=5:輸入 x。type=6:輸入 x,y。接下來一行一個數 M2,表示第二問的詢問數。接下來 M2 行:type=7:輸入 x,k。type=8:輸入 x,k。type=9:輸入 x,y,k。type=10:輸入 x,y,k。

最后一行一個整數 k。以上輸入意義見題中所述?!据敵鰯祿繉τ诿總€查詢操作,每行輸出一個答案。最后一行為最后一問的答案?!据斎霕永?1】500000122324356134432133342546344722835934210 4 5 23【輸出樣例 1】4519515010【輸入樣例 2、3】見下發樣例文件?!据敵鰳永?2、3】見下發樣例文件。【數據約定】對于 30%的數據,滿足 N<=3000。M1,M2<=3000。對于 100%的數據,滿足 N<=100000。M1,M2<=100000。(ps:簡單送肉板子題,應該有人 AC 吧。。)

正解:樹鏈剖分+線段樹+主席樹+點分治。

全部是板子,出了這道題為了訓練代碼能力??紙錾蠠o人寫出正解,1人寫對30分暴力。。

//It is made by wfj_2048~#include <algorithm>#include <iostream>#include <cstring>#include <cstdlib>#include <cstdio>#include <vector>#include <cmath>#include <queue>#include <stack>#include <map>#include <set>#define N (100010)#define inf (1<<30)#define lson (x<<1)#define rson (x<<1|1)#define il inline#define RG register#define ll long long#define File(s) freopen(s".in","r",stdin),freopen(s".out","w",stdout)using namespace std;struct edge{	ll nt,to;} g[2*N];ll head[N],top[N],fa[N],son[N],size[N],dep[N],dfn[N],pos[N],cur[N],vis[N],dis[N],a[N],W[N],num[N],hsh[N],root1[N],root2[N],lazy[4*N],sum[4*N],sum1[20*N],sum2[20*N],ls1[20*N],rs1[20*N],ls2[20*N],rs2[20*N],n,ssz,sz,sz1,sz2,cnt,tot,root,limit,ans;il ll gi(){	RG ll x=0,q=1;	RG char ch=getchar();	while ((ch<'0' || ch>'9') && ch!='-') ch=getchar();	if (ch=='-') q=-1,ch=getchar();	while (ch>='0' && ch<='9') x=x*10+ch-48,ch=getchar();	return q*x;}il void insert(RG ll from,RG ll to){	g[++sz]=(edge) {head[from],to},head[from]=sz;	return;}il void dfs1(RG ll x,RG ll p){	dep[x]=dep[p]+1,fa[x]=p,size[x]=1;	RG ll v,mx=0;	for (RG ll i=head[x]; i; i=g[i].nt)	{		v=g[i].to;		if (v==p) continue;		dfs1(v,x);		size[x]+=size[v];		if (size[mx]<=size[v]) mx=v;	}	son[x]=mx;	return;}il void dfs2(RG ll x,RG ll p,RG ll a){	top[x]=a,dfn[x]=++cnt,pos[cnt]=x;	if (son[x]) dfs2(son[x],x,a);	RG ll v;	for (RG ll i=head[x]; i; i=g[i].nt)	{		v=g[i].to;		if (v==p || v==son[x]) continue;		dfs2(v,x,v);	}	return;}il void down(RG ll x,RG ll l,RG ll r){	RG ll mid=(l+r)>>1;	sum[lson]+=lazy[x]*(mid-l+1),sum[rson]+=lazy[x]*(r-mid);	lazy[lson]+=lazy[x],lazy[rson]+=lazy[x],lazy[x]=0;	return;}il void build(RG ll x,RG ll l,RG ll r){	if (l==r)	{		sum[x]=a[pos[l]];		return;	}	RG ll mid=(l+r)>>1;	build(lson,l,mid);	build(rson,mid+1,r);	sum[x]=sum[lson]+sum[rson];	return;}il void update(RG ll x,RG ll l,RG ll r,RG ll xl,RG ll xr,RG ll v,RG ll flag){	if (xl<=l && r<=xr)	{		if (flag) sum[x]+=(r-l+1)*v,lazy[x]+=v;		else sum[x]=v;		return;	}	if (lazy[x]) down(x,l,r);	RG ll mid=(l+r)>>1;	if (xr<=mid) update(lson,l,mid,xl,xr,v,flag);	else if (xl>mid) update(rson,mid+1,r,xl,xr,v,flag);	else	{		update(lson,l,mid,xl,mid,v,flag);		update(rson,mid+1,r,mid+1,xr,v,flag);	}	sum[x]=sum[lson]+sum[rson];	return;}il ll query(RG ll x,RG ll l,RG ll r,RG ll xl,RG ll xr){	if (xl<=l && r<=xr) return sum[x];	if (lazy[x]) down(x,l,r);	RG ll mid=(l+r)>>1;	if (xr<=mid) return query(lson,l,mid,xl,xr);	else if (xl>mid) return query(rson,mid+1,r,xl,xr);	else return query(lson,l,mid,xl,mid)+query(rson,mid+1,r,mid+1,xr);}il void change(RG ll u,RG ll v,RG ll w){	while (top[u]!=top[v])	{		if (dep[top[u]]<dep[top[v]]) swap(u,v);		update(1,1,n,dfn[top[u]],dfn[u],w,1);		u=fa[top[u]];	}	if (dep[u]>dep[v]) swap(u,v);	update(1,1,n,dfn[u],dfn[v],w,1);	return;}il ll Query(RG ll u,RG ll v){	RG ll res=0;	while (top[u]!=top[v])	{		if (dep[top[u]]<dep[top[v]]) swap(u,v);		res+=query(1,1,n,dfn[top[u]],dfn[u]);		u=fa[top[u]];	}	if (dep[u]>dep[v]) swap(u,v);	res+=query(1,1,n,dfn[u],dfn[v]);	return res;}il ll lca(RG ll u,RG ll v){	while (top[u]!=top[v])	{		if (dep[top[u]]<dep[top[v]]) swap(u,v);		u=fa[top[u]];	}	return dep[u]>dep[v] ? v : u;}il void kth1build(RG ll x,RG ll &y,RG ll l,RG ll r,RG ll v){	sum1[y=++sz1]=sum1[x]+1,ls1[y]=ls1[x],rs1[y]=rs1[x];	if (l==r) return;	RG ll mid=(l+r)>>1;	if (v<=mid) kth1build(ls1[x],ls1[y],l,mid,v);	else kth1build(rs1[x],rs1[y],mid+1,r,v);	return;}il ll kth1query1(RG ll x,RG ll y,RG ll k){	RG ll l=1,r=tot,mid,tmp;	while (l<r)	{		mid=(l+r)>>1,tmp=sum1[ls1[y]]-sum1[ls1[x]];		if (k<=tmp) r=mid,x=ls1[x],y=ls1[y];		else l=mid+1,k-=tmp,x=rs1[x],y=rs1[y];	}	return hsh[l];}il ll kth1query2(RG ll x,RG ll y,RG ll k){	if (!k) return 0;	RG ll l=1,r=tot,mid,ans=0;	while (l<r)	{		mid=(l+r)>>1;		if (k<=mid) r=mid,x=ls1[x],y=ls1[y];		else		{			ans+=sum1[ls1[y]]-sum1[ls1[x]];			l=mid+1,x=rs1[x],y=rs1[y];		}	}	return ans+sum1[y]-sum1[x];}il void kth2build(RG ll x,RG ll &y,RG ll l,RG ll r,RG ll v){	sum2[y=++sz2]=sum2[x]+1,ls2[y]=ls2[x],rs2[y]=rs2[x];	if (l==r) return;	RG ll mid=(l+r)>>1;	if (v<=mid) kth2build(ls2[x],ls2[y],l,mid,v);	else kth2build(rs2[x],rs2[y],mid+1,r,v);	return;}il ll kth2query1(RG ll u,RG ll v,RG ll k){	RG ll Lca=lca(u,v),l=1,r=tot,mid,tmp;	RG ll a=root2[dfn[u]],b=root2[dfn[v]];	RG ll c=root2[dfn[Lca]],d=root2[dfn[fa[Lca]]];	while (l<r)	{		mid=(l+r)>>1,tmp=sum2[ls2[a]]+sum2[ls2[b]]-sum2[ls2[c]]-sum2[ls2[d]];		if (k<=tmp) r=mid,a=ls2[a],b=ls2[b],c=ls2[c],d=ls2[d];		else k-=tmp,l=mid+1,a=rs2[a],b=rs2[b],c=rs2[c],d=rs2[d];	}	return hsh[l];}il ll kth2query2(RG ll u,RG ll v,RG ll k){	if (!k) return 0;	RG ll Lca=lca(u,v),l=1,r=tot,mid,ans=0;	RG ll a=root2[dfn[u]],b=root2[dfn[v]],c=root2[dfn[Lca]],d=root2[dfn[fa[Lca]]];	while (l<r)	{		mid=(l+r)>>1;		if (k<=mid) r=mid,a=ls2[a],b=ls2[b],c=ls2[c],d=ls2[d];		else		{			ans+=sum2[ls2[a]]+sum2[ls2[b]]-sum2[ls2[c]]-sum2[ls2[d]],l=mid+1;			a=rs2[a],b=rs2[b],c=rs2[c],d=rs2[d];		}	}	return ans+sum2[a]+sum2[b]-sum2[c]-sum2[d];}il void dfs3(RG ll x){	kth2build(root2[dfn[fa[x]]],root2[dfn[x]],1,tot,num[dfn[x]]);	for (RG ll i=head[x]; i; i=g[i].nt)	{		RG ll v=g[i].to;		if (v==fa[x]) continue;		dfs3(v);	}	return;}il void getroot(RG ll x,RG ll p){	size[x]=1,son[x]=0;	for (RG ll i=head[x]; i; i=g[i].nt)	{		RG ll v=g[i].to;		if (vis[v] || v==p) continue;		getroot(v,x);		size[x]+=size[v];		son[x]=max(son[x],size[v]);	}	son[x]=max(son[x],son[0]-size[x]);	if (son[x]<son[root]) root=x;	return;}il void getdis(RG ll x,RG ll p){	cur[++ssz]=dis[x];	for (RG ll i=head[x]; i; i=g[i].nt)	{		RG ll v=g[i].to;		if (vis[v] || v==p) continue;		dis[v]=dis[x]+1;		getdis(v,x);	}	return;}il ll cont(RG ll x,RG ll mit){	RG ll res=0;	dis[x]=mit,ssz=0;	getdis(x,0);	sort(cur+1,cur+ssz+1);	for (RG ll l=1,r=ssz; l<r;)		if (cur[l]+cur[r]<=limit) res+=(r-l++);		else r--;	return res;}il void solve(RG ll x){	vis[x]=1;	ans+=cont(x,0);	for (RG ll i=head[x]; i; i=g[i].nt)	{		RG ll v=g[i].to;		if (vis[v]) continue;		ans-=cont(v,1),root=0,son[0]=size[v];		getroot(v,0),solve(root);	}	return;}il void work(){	n=gi();	RG ll m1,m2,u,v,w,x,k,type;	for (RG ll i=1; i<=n; ++i) a[i]=gi();	for (RG ll i=1; i<n; ++i)	{		u=gi(),v=gi();		insert(u,v),insert(v,u);	}	dfs1(1,0),dfs2(1,0,1);	build(1,1,n);	m1=gi();	for (RG ll i=1; i<=m1; ++i)	{		type=gi();		if (type==1)		{			x=gi(),w=gi();			update(1,1,n,dfn[x],dfn[x],w,0);		}		if (type==2)		{			x=gi(),w=gi();			update(1,1,n,dfn[x],dfn[x]+size[x]-1,w,1);		}		if (type==3)		{			u=gi(),v=gi(),w=gi();			change(u,v,w);		}		if (type==4)		{			x=gi();			PRintf("%lld/n",query(1,1,n,dfn[x],dfn[x]));		}		if (type==5)		{			x=gi();			printf("%lld/n",query(1,1,n,dfn[x],dfn[x]+size[x]-1));		}		if (type==6)		{			u=gi(),v=gi();			printf("%lld/n",Query(u,v));		}	}	for (RG ll i=1; i<=n; ++i) num[i]=W[i]=query(1,1,n,i,i);	sort(num+1,num+n+1);	hsh[tot=1]=num[1];	for (RG ll i=2; i<=n; ++i) if (num[i]>num[i-1]) hsh[++tot]=num[i];	for (RG ll i=1; i<=n; ++i) num[i]=lower_bound(hsh+1,hsh+tot+1,W[i])-hsh;	for (RG ll i=1; i<=n; ++i) kth1build(root1[i-1],root1[i],1,tot,num[i]);	dfs3(1);	m2=gi();	for (RG ll i=1; i<=m2; ++i)	{		type=gi();		if (type==7)		{			x=gi(),k=gi();			printf("%lld/n",kth1query1(root1[dfn[x]-1],root1[dfn[x]+size[x]-1],k));		}		if (type==8)		{			x=gi(),k=gi();			if (k>hsh[tot]) k=tot;			else if (k<hsh[1]) k=0;			else k=upper_bound(hsh+1,hsh+tot+1,k)-hsh-1;			printf("%lld/n",kth1query2(root1[dfn[x]-1],root1[dfn[x]+size[x]-1],k));		}		if (type==9)		{			u=gi(),v=gi(),k=gi();			printf("%lld/n",kth2query1(u,v,k));		}		if (type==10)		{			u=gi(),v=gi(),k=gi();			if (k>hsh[tot]) k=tot;			else if (k<hsh[1]) k=0;			else k=upper_bound(hsh+1,hsh+tot+1,k)-hsh-1;			printf("%lld/n",kth2query2(u,v,k));		}	}	limit=gi();	ans=0,root=0,son[0]=n;	getroot(1,0);	solve(root);	printf("%lld/n",ans);	return;}int main(){	File("structure");	work();	return 0;}


發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
国产精品毛片a∨一区二区三区|国| 国产视频亚洲精品| 久久久国产影院| 在线观看国产精品日韩av| 久久久成人av| 亚洲无限乱码一二三四麻| 亚洲欧美国产一本综合首页| 91久久精品一区| 中文字幕久久精品| 91av在线免费观看视频| 91精品视频在线| 亚洲精品v欧美精品v日韩精品| 色香阁99久久精品久久久| 国产一区二区三区高清在线观看| 亚洲变态欧美另类捆绑| 日韩成人在线视频网站| 精品视频一区在线视频| 久久久国产视频91| 国产精品高清网站| 亚洲成人1234| 激情亚洲一区二区三区四区| 人九九综合九九宗合| 亚洲综合色激情五月| 欧美精品少妇videofree| 美女久久久久久久| 欧美成人午夜影院| 久久久国产在线视频| 亚洲在线视频观看| 国产99在线|中文| 免费成人高清视频| 亚洲毛片在线免费观看| 欧美激情二区三区| 精品高清美女精品国产区| 成人精品网站在线观看| 亚洲japanese制服美女| 亚洲成人精品视频在线观看| 欧美激情在线观看| 国内免费久久久久久久久久久| 日韩精品中文字幕视频在线| 97国产精品视频人人做人人爱| 国产精品美女无圣光视频| 中文字幕亚洲色图| 国产精品h在线观看| 亚洲人成网站777色婷婷| 日韩在线视频国产| 精品伊人久久97| 亚洲欧洲在线免费| 亚洲性线免费观看视频成熟| 日韩在线免费高清视频| 精品成人在线视频| 亚洲精品一区二区三区不| 日韩中文在线中文网三级| 亚洲成**性毛茸茸| 色yeye香蕉凹凸一区二区av| 国产aⅴ夜夜欢一区二区三区| 97久久伊人激情网| 黑人巨大精品欧美一区二区三区| 日本精品久久久久久久| 久久久久久久久国产精品| 不卡在线观看电视剧完整版| 欧美日韩免费区域视频在线观看| 91欧美精品午夜性色福利在线| 大桥未久av一区二区三区| 欧美激情亚洲综合一区| 久久99视频精品| 亚洲国产精品99| 日韩暖暖在线视频| 成人黄色av播放免费| 欧美激情中文字幕乱码免费| 亚洲欧美制服丝袜| 国产精品久久久久久久久久久久久| 成人免费观看49www在线观看| 国产精品久久久精品| 91网站免费看| 日韩电影中文字幕在线观看| 欧美久久精品午夜青青大伊人| 国产精品第一区| 久久久999国产精品| 国产成人免费91av在线| 亚洲美女中文字幕| 亚洲综合在线小说| 亚洲精品一区二区久| 日韩电影大全免费观看2023年上| 国产精品日韩欧美| 97国产精品视频| 国产成人免费av电影| 亚洲精品456在线播放狼人| 亚洲午夜激情免费视频| 狠狠色狠狠色综合日日五| 精品视频在线观看日韩| 亚洲欧美精品一区| 亚洲天堂一区二区三区| 亚州国产精品久久久| 国产精品美女www爽爽爽视频| 欧美中文字幕视频在线观看| 亚洲一区二区三区xxx视频| 久久伊人91精品综合网站| 久久精品亚洲国产| 91免费看视频.| 欧美高清视频在线观看| 国产精品嫩草视频| 久久久爽爽爽美女图片| 久久精品中文字幕电影| 久久精品人人做人人爽| 日韩美女福利视频| 欧洲精品在线视频| 精品少妇v888av| 美女999久久久精品视频| 欧美黑人巨大精品一区二区| 国产精品美女免费视频| 精品国产一区二区三区久久久狼| 欧美精品激情在线观看| 国产精品自拍小视频| 在线性视频日韩欧美| 色综合久久88| 日韩精品中文在线观看| 色小说视频一区| 日韩欧美国产激情| 日韩黄色在线免费观看| 不卡av电影院| 中文字幕在线看视频国产欧美在线看完整| 麻豆成人在线看| 91免费看片网站| 深夜福利91大全| 国产精品日韩在线一区| 2019av中文字幕| 久久精品视频在线观看| 综合网日日天干夜夜久久| 热re99久久精品国产66热| 精品亚洲va在线va天堂资源站| 国产精品91久久久| 国内免费久久久久久久久久久| 日韩精品丝袜在线| 日韩av在线免费观看一区| 久久精品久久久久久国产 免费| 欧美精品激情在线观看| 18性欧美xxxⅹ性满足| 亚洲三级 欧美三级| 国产区精品在线观看| 国产欧美日韩免费| 在线日韩第一页| 亚洲成人黄色网址| 国产欧美精品一区二区三区介绍| 中文字幕av一区二区| 91中文字幕在线| 久久99久久99精品中文字幕| 亚洲精品欧美日韩| 午夜精品视频在线| 精品久久久av| 亚洲免费伊人电影在线观看av| 97精品一区二区视频在线观看| 精品日本美女福利在线观看| 午夜欧美大片免费观看| 日韩欧美国产网站| 国产精品成人免费视频| 久久影视电视剧免费网站清宫辞电视| 亚洲电影成人av99爱色| 91九色综合久久| 91免费人成网站在线观看18| 国产视频在线观看一区二区| 欧美大秀在线观看| 日韩中文娱乐网| 久久久久在线观看| 亚洲免费成人av电影|