日韩av黄I国产麻豆传媒I国产91av视频在线观看I日韩一区二区三区在线看I美女国产在线I麻豆视频国产在线观看I成人黄色短片

歡迎訪問(wèn) 生活随笔!

生活随笔

當(dāng)前位置: 首頁(yè) > 编程资源 > 编程问答 >内容正文

编程问答

虚树总结

發(fā)布時(shí)間:2024/4/11 编程问答 42 豆豆
生活随笔 收集整理的這篇文章主要介紹了 虚树总结 小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.

之前的之前

之前的之前,可以做做這題,領(lǐng)略虛樹(shù)的思想
洛谷P3320 [SDOI2015]尋寶游戲
我在洛谷上的題解

學(xué)習(xí)之前的例題

在學(xué)虛樹(shù)之前,先來(lái)看一道題:
洛谷P2495 [SDOI2011]消耗戰(zhàn)
大致題意是這樣的,現(xiàn)在有n個(gè)點(diǎn),n-1條帶權(quán)邊的樹(shù),有m個(gè)詢問(wèn),每個(gè)詢問(wèn),給出k個(gè)點(diǎn),(其中不包含1號(hào)節(jié)點(diǎn)),要?jiǎng)h除一些邊使得1號(hào)點(diǎn)與給出的點(diǎn)不連通,求刪除邊和的最小值。

乍一看,是不是覺(jué)得顯然是樹(shù)形dp呢,而且樹(shù)形dp還是Θ(n)\Theta(n)Θ(n)的,十分優(yōu)越
但是,不幸的是,2≤n≤2500002\le n\le2500002n250000的情況下,1≤m≤5000001\le m\le5000001m500000,如果是Θ(nm)\Theta(nm)Θ(nm)顯然會(huì)TLE,但是又有一個(gè)好消息Σki≤500000\Sigma k_i\le500000Σki?500000

那么考慮一下怎么做,可能有些難想,這個(gè)時(shí)候就該引入虛樹(shù)啦,此題可以用虛樹(shù)解決

虛樹(shù)的概念

虛樹(shù),就是在有一棵樹(shù)的情況下,對(duì)于數(shù)量較少的點(diǎn)進(jìn)行詢問(wèn)時(shí)所建的一棵新的樹(shù),虛樹(shù)包含詢問(wèn)的點(diǎn)和詢問(wèn)的點(diǎn)的lca(最近公共祖先),上面的點(diǎn)被稱為關(guān)鍵點(diǎn)。對(duì)于兩個(gè)關(guān)鍵點(diǎn)A,B,它們的連邊上包含著原本樹(shù)上兩點(diǎn)之間那條鏈上的關(guān)鍵信息(這個(gè)信息可以是邊權(quán)最大值、邊權(quán)最小值、或者是邊權(quán)之和,這個(gè)取決于實(shí)際需要),然后就可以進(jìn)行樹(shù)形dp了,這樣的復(fù)雜度是基于詢問(wèn)的點(diǎn)數(shù)的,就可以想象虛樹(shù)就是把一棵大樹(shù)濃縮成一棵擁有所有你需要的信息的小樹(shù)。

建樹(shù)的方法

那么怎么建樹(shù)呢,比較常見(jiàn)的做法是維護(hù)一個(gè)棧,里面存儲(chǔ)著一條鏈,每一次加入一個(gè)點(diǎn)進(jìn)行操作。
具體列舉一下步驟吧

預(yù)備知識(shí):

用較優(yōu)的復(fù)雜度求lca,以及求兩點(diǎn)之間的距離,一般倍增做,或者樹(shù)鏈剖分加前綴和都可以,這都是單次Θ(logn)\Theta(logn)Θ(logn)的,另外呢,要事先求好原樹(shù)的dfs序和每個(gè)點(diǎn)的深度(這里的深度是指點(diǎn)序的深度,在計(jì)算這個(gè)深度的時(shí)候每條邊都是為1來(lái)算),后面要用

詢問(wèn)操作:

1.輸入每個(gè)詢問(wèn)的點(diǎn),并且按照dfs序?yàn)殛P(guān)鍵字排序
2.將第1個(gè)點(diǎn)壓到棧當(dāng)中,開(kāi)始構(gòu)建虛樹(shù)
3.枚舉到下一個(gè)點(diǎn)u,計(jì)算u與棧頂點(diǎn)v的公共祖先lca
4.假設(shè)棧中棧頂下方的點(diǎn)為w(若棧中只有1個(gè)點(diǎn)就直跳過(guò)這一步),若w點(diǎn)的深度大于lca就把v向w連一條邊,并且彈掉v,重復(fù)此步,否則就到下一步
5.若lca不是當(dāng)前的v,那么就把lca和v連邊,把v彈出,讓lca成為棧頂元素(注:這個(gè)操作的意思是如果棧頂沒(méi)有這個(gè)lca那么就壓入),否則不做任何操作
6.最后把u壓入棧中
7.回到3操作枚舉下個(gè)點(diǎn),直到枚舉完了所有點(diǎn)
8.把棧頂v與棧頂下方的點(diǎn)為w連邊,并且把v彈掉,這么做直到棧里只有一個(gè)點(diǎn)
9.棧里剩下的點(diǎn)就是虛樹(shù)的根了
接下來(lái)你就可以開(kāi)始進(jìn)行dp等操作了

虛樹(shù)的復(fù)雜度

虛樹(shù)的建樹(shù)的復(fù)雜度是Θ(klogn)\Theta(klogn)Θ(klogn)的,樹(shù)形dp就是Θ(k)\Theta(k)Θ(k)的啦,因?yàn)榭紤]最后虛樹(shù)上的關(guān)鍵點(diǎn)有詢問(wèn)的點(diǎn),和lca,然后每個(gè)詢問(wèn)的點(diǎn)最多產(chǎn)生1個(gè)新的lca,所以復(fù)雜度就是對(duì)的啦

有關(guān)虛樹(shù)用建樹(shù)的幾點(diǎn)技巧

首先棧里面最后剩下的點(diǎn)就是虛樹(shù)的根節(jié)點(diǎn),這個(gè)很好用
然后對(duì)于很多題目建虛樹(shù)都要建多次,那么 鄰接表/vector 的同學(xué)都要清空 head/vector ,如果 memset/一個(gè)個(gè)枚舉clear 那肯定會(huì)T的,我往往都會(huì)在樹(shù)形dp時(shí)用完邊后進(jìn)行清空,就非常高效了

開(kāi)頭的題的題解

對(duì)于這一題把1號(hào)點(diǎn)作為根,對(duì)于每個(gè)詢問(wèn)都建一棵虛樹(shù),然后進(jìn)行樹(shù)形dp,這一題當(dāng)中可以發(fā)現(xiàn)若一個(gè)點(diǎn)是另一個(gè)點(diǎn)的祖先,那么只需保留深度小的那個(gè)點(diǎn),那么建好的虛樹(shù)中只有葉子節(jié)點(diǎn)是需要被截?cái)嗟?#xff0c;樹(shù)形dp可以用f[i][0]表示截?cái)鄆點(diǎn)的子節(jié)點(diǎn)的最小代價(jià),f[i][1]表示不截?cái)嗟淖钚〈鷥r(jià)(當(dāng)然可以少一維,但是為了方便我就這么定義啦)
下面是代碼

#include<cstdio> #include<cctype> namespace fast_IO {const int IN_LEN=10000000,OUT_LEN=10000000;char ibuf[IN_LEN],obuf[OUT_LEN],*ih=ibuf+IN_LEN,*oh=obuf,*lastin=ibuf+IN_LEN,*lastout=obuf+OUT_LEN-1;inline char getchar_(){return (ih==lastin)&&(lastin=(ih=ibuf)+fread(ibuf,1,IN_LEN,stdin),ih==lastin)?EOF:*ih++;}inline void putchar_(const char x){if(oh==lastout)fwrite(obuf,1,oh-obuf,stdout),oh=obuf;*oh++=x;}inline void flush(){fwrite(obuf,1,oh-obuf,stdout);} } using namespace fast_IO; #define getchar() getchar_() #define putchar(x) putchar_((x)) typedef long long LL; #define rg register template <typename T> inline T max(const T a,const T b){return a>b?a:b;} template <typename T> inline T min(const T a,const T b){return a<b?a:b;} template <typename T> inline T abs(const T a){return a>0?a:-a;} template <typename T> inline void swap(T&a,T&b){T c=a;a=b;b=c;} template <typename T> inline T gcd(const T a,const T b){if(a%b==0)return b;return gcd(b,a%b);} template <typename T> inline T square(const T x){return x*x;}; template <typename T> inline void read(T&x) {char cu=getchar();x=0;bool fla=0;while(!isdigit(cu)){if(cu=='-')fla=1;cu=getchar();}while(isdigit(cu))x=x*10+cu-'0',cu=getchar();if(fla)x=-x; } template <typename T> void printe(const T x) {if(x>=10)printe(x/10);putchar(x%10+'0'); } template <typename T> inline void print(const T x) {if(x<0)putchar('-'),printe(-x);else printe(x); } inline void judge() {freopen("1.in","r",stdin);freopen("1.out","w",stdout); } #include<cstring> #include<algorithm> const int maxn=250001,maxm=500001; int bit[19]; int n,m,s; int head[maxn],nxt[maxm],tow[maxm],vau[maxm],tmp=1; int who[maxn][19],dis[maxn][19]; int dep[maxn]; inline void addb(const int u,const int v,const int w) {tmp++;nxt[tmp]=head[u];head[u]=tmp;tow[tmp]=v;vau[tmp]=w; } int tid[maxn],tim; inline void dfs(const int u) {tid[u]=++tim;for(rg int i=head[u];i;i=nxt[i]){const int v=tow[i];if(who[u][0]!=v){who[v][0]=u;dis[v][0]=vau[i];dep[v]=dep[u]+1;dfs(v);}} } inline int lca(int a,int b) {if(dep[a]<dep[b])swap(a,b);const int lenth=dep[a]-dep[b];for(rg int i=0;bit[i]<=lenth;i++)if(lenth&bit[i])a=who[a][i];if(a==b)return a;for(rg int i=18;i>=0;i--)if(who[a][i]!=who[b][i])a=who[a][i],b=who[b][i];return who[a][0]; } inline int dist(int a,int b) {rg int ans=0x7fffffff;if(dep[a]<dep[b])swap(a,b);const int lenth=dep[a]-dep[b];for(rg int i=0;bit[i]<=lenth;i++)if(lenth&bit[i])ans=min(ans,dis[a][i]),a=who[a][i];if(a==b)return ans;for(rg int i=18;i>=0;i--)if(who[a][i]!=who[b][i])ans=min(ans,min(dis[a][i],dis[b][i])),a=who[a][i],b=who[b][i];return min(ans,min(dis[a][0],dis[b][0])); } int head_[maxn],nxt_[maxm],tow_[maxm],vau_[maxm],tmp_; inline void addb_(const int u,const int v,const int w) {tmp_++;nxt_[tmp_]=head_[u];head_[u]=tmp_;tow_[tmp_]=v;vau_[tmp_]=w; } int k,h[maxn]; bool cmp(const int x,const int y) {return tid[x]<tid[y]; } int stack[maxn],top; LL dp[maxn][2]; void dfs(const int u,const int fa) {rg bool sign=1;dp[u][0]=dp[u][1]=0;for(rg int i=head_[u];i;i=nxt_[i]){const int v=tow_[i];if(v!=fa){dfs(v,u);dp[u][0]+=min(dp[v][0],dp[v][1]+vau_[i]);dp[u][1]+=dp[v][1];sign=0;}}head_[u]=0;if(sign)dp[u][0]=0x7fffffffffffffff;dp[u][1]=min(dp[u][1],dp[u][0]); } int main() { // judge();memset(dis,0x7f,sizeof(dis));bit[0]=1;for(rg int i=1;i<=18;i++)bit[i]=bit[i-1]<<1;read(n),s=1;for(rg int i=1;i<n;i++){int u,v,w;read(u),read(v),read(w);addb(u,v,w),addb(v,u,w);}who[s][0]=s,dep[s]=1;dfs(s);for(rg int j=1;j<=18;j++)for(rg int i=1;i<=n;i++)who[i][j]=who[who[i][j-1]][j-1],dis[i][j]=min(dis[i][j-1],dis[who[i][j-1]][j-1]);read(m);for(rg int i=1;i<=m;i++){read(k);for(rg int j=1;j<=k;j++)read(h[j]);std::sort(h+1,h+k+1,cmp);tmp_=0;rg int sum=0;h[++sum]=h[1];for(rg int j=2;j<=k;j++)if(lca(h[sum],h[j])!=h[sum])h[++sum]=h[j];k=sum;top=0,stack[++top]=1;for(rg int j=1;j<=k;j++){const int LCA=lca(stack[top],h[j]);while(top>1&&dep[stack[top-1]]>dep[LCA]){const int DIS=dist(stack[top-1],stack[top]);addb_(stack[top-1],stack[top],DIS),addb_(stack[top],stack[top-1],DIS);top--;}if(dep[stack[top]]>dep[LCA]){const int DIS=dist(LCA,stack[top]);addb_(LCA,stack[top],DIS),addb_(stack[top],LCA,DIS);top--;}if(!top||dep[stack[top]]<dep[LCA])stack[++top]=LCA;stack[++top]=h[j];}while(top>1){const int DIS=dist(stack[top-1],stack[top]);addb_(stack[top-1],stack[top],DIS),addb_(stack[top],stack[top-1],DIS);top--;}dfs(1,0);print(dp[1][0]);putchar('\n');}return 0; }

再來(lái)一題

由于前面那題有一些特殊性質(zhì),代碼可能不能作為虛樹(shù)的模板,所以呢,現(xiàn)在再引入一道題
洛谷P3233 [HNOI2014]世界樹(shù)
簡(jiǎn)要題意就是現(xiàn)在有一棵n個(gè)點(diǎn),n-1條邊的樹(shù),給出q個(gè)詢問(wèn),每次詢問(wèn)給出mi個(gè)重要點(diǎn),樹(shù)上的每一個(gè)點(diǎn)都屬于離其最近的重要點(diǎn),若有多個(gè)點(diǎn)滿足條件,那么它屬于這其中編號(hào)最小的點(diǎn),對(duì)于每個(gè)詢問(wèn)中需要輸出每個(gè)給出的重要點(diǎn)所管轄點(diǎn)的數(shù)量。n<=300000,q<=300000,m[1]+m[2]+…+m[q]<=300000
怎么做,很顯然還是通過(guò)建虛樹(shù)然后進(jìn)行樹(shù)形dp啦,這道題其實(shí)有些麻煩,后面的樹(shù)形dp賊煩(為了便于理解,我dfs了多遍,導(dǎo)致代碼量大大增加),對(duì)于每條虛樹(shù)邊都可能屬于一個(gè)點(diǎn)或者被瓜分成兩份,對(duì)于虛樹(shù)上的非關(guān)鍵點(diǎn),首先計(jì)算它屬于哪個(gè)點(diǎn),然后算出它的出邊的樹(shù)中不屬于自己所在重要點(diǎn)的點(diǎn)的數(shù)量(除了朝向自己屬于的重要點(diǎn)的方向,這個(gè)可以通過(guò)和重要點(diǎn)的距離來(lái)判),然后對(duì)于每一個(gè)重要點(diǎn)所管轄點(diǎn)的數(shù)量是n-不屬于自己的點(diǎn)的數(shù)量就好了。解釋可能不是很清楚,下面貼出代碼(update:由于寫此份代碼的時(shí)候太菜,思路不夠清晰,所以當(dāng)時(shí)為了方便思考導(dǎo)致樹(shù)形dp這一部分寫的很長(zhǎng),實(shí)際樹(shù)形dp的清真實(shí)現(xiàn)可以去參考網(wǎng)上的其它代碼):

#include<cstdio> #include<cctype> #include<algorithm> #include<cstring> namespace fast_IO {const int IN_LEN=10000000,OUT_LEN=10000000;char ibuf[IN_LEN],obuf[OUT_LEN],*ih=ibuf+IN_LEN,*oh=obuf,*lastin=ibuf+IN_LEN,*lastout=obuf+OUT_LEN-1;inline char getchar_(){return (ih==lastin)&&(lastin=(ih=ibuf)+fread(ibuf,1,IN_LEN,stdin),ih==lastin)?EOF:*ih++;}inline void putchar_(const char x){if(oh==lastout)fwrite(obuf,1,oh-obuf,stdout),oh=obuf;*oh++=x;}inline void flush(){fwrite(obuf,1,oh-obuf,stdout);} } using namespace fast_IO; #define getchar() getchar_() #define putchar(x) putchar_((x)) #define rg register typedef long long LL; template <typename T> inline T max(const T a,const T b){return a>b?a:b;} template <typename T> inline T min(const T a,const T b){return a<b?a:b;} template <typename T> inline void mind(T&a,const T b){a=a<b?a:b;} template <typename T> inline void maxd(T&a,const T b){a=a>b?a:b;} template <typename T> inline T abs(const T a){return a>0?a:-a;} template <typename T> inline void swap(T&a,T&b){T c=a;a=b;b=c;} template <typename T> inline T gcd(const T a,const T b){if(!b)return a;return gcd(b,a%b);} template <typename T> inline T lcm(const T a,const T b){return a/gcd(a,b)*b;} template <typename T> inline T square(const T x){return x*x;}; template <typename T> inline void read(T&x) {char cu=getchar();x=0;bool fla=0;while(!isdigit(cu)){if(cu=='-')fla=1;cu=getchar();}while(isdigit(cu))x=x*10+cu-'0',cu=getchar();if(fla)x=-x; } template <typename T> inline void printe(const T x) {if(x>=10)printe(x/10);putchar(x%10+'0'); } template <typename T> inline void print(const T x) {if(x<0)putchar('-'),printe(-x);else printe(x); } const int maxn=300001,maxm=600001; int bit[19]; int n,m,s; int head[maxn],nxt[maxm],tow[maxm],tmp=1; int who[maxn][19],dis[maxn][19]; int dep[maxn]; inline void addb(const int u,const int v) {tmp++;nxt[tmp]=head[u];head[u]=tmp;tow[tmp]=v; } int tid[maxn],tim,size[maxn]; inline void dfs(const int u) {tid[u]=++tim,size[u]=1;for(rg int i=head[u];i;i=nxt[i]){const int v=tow[i];if(who[u][0]!=v){who[v][0]=u;dis[v][0]=1;dep[v]=dep[u]+1;dfs(v);size[u]+=size[v]; }} } inline int lca(int a,int b) {if(dep[a]<dep[b])swap(a,b);const int lenth=dep[a]-dep[b];for(rg int i=0;bit[i]<=lenth;i++)if(lenth&bit[i])a=who[a][i];if(a==b)return a;for(rg int i=18;i>=0;i--)if(who[a][i]!=who[b][i])a=who[a][i],b=who[b][i];return who[a][0]; } inline int dist(int a,int b) {rg int ans=0;if(dep[a]<dep[b])swap(a,b);const int lenth=dep[a]-dep[b];for(rg int i=0;bit[i]<=lenth;i++)if(lenth&bit[i])ans+=dis[a][i],a=who[a][i];if(a==b)return ans;for(rg int i=18;i>=0;i--)if(who[a][i]!=who[b][i])ans+=dis[a][i]+dis[b][i],a=who[a][i],b=who[b][i];return ans+dis[a][0]+dis[b][0]; } int head_[maxn],nxt_[maxm],tow_[maxm],vau_[maxm],tmp_; inline void addb_(const int u,const int v,const int w) {tmp_++;nxt_[tmp_]=head_[u];head_[u]=tmp_;tow_[tmp_]=v;vau_[tmp_]=w; } int k,h[maxn],ans[maxn],belo[maxn],Dis[maxn]; int qu[maxn]; bool sign[maxn]; bool cmp(const int x,const int y) {return tid[x]<tid[y]; } int stack[maxn],top; inline int check(int u,const int lenth) {for(rg int i=0;bit[i]<=lenth;i++)if(lenth&bit[i])u=who[u][i];return u; } void dfs1_0(const int u,const int fa) {if(sign[u]){for(rg int i=head_[u];i;i=nxt_[i]){const int v=tow_[i];if(v!=fa)dfs1_0(v,u);}}else{for(rg int i=head_[u];i;i=nxt_[i]){const int v=tow_[i];if(v!=fa){dfs1_0(v,u);if(sign[v]){if(vau_[i]<Dis[u]||vau_[i]==Dis[u]&&v<belo[u])belo[u]=v,Dis[u]=vau_[i];}else{if(vau_[i]+Dis[v]<Dis[u]||vau_[i]+Dis[v]==Dis[u]&&belo[v]<belo[u])belo[u]=belo[v],Dis[u]=vau_[i]+Dis[v];}}}} } void dfs1_1(const int u,const int fa) {if(sign[u]){for(rg int i=head_[u];i;i=nxt_[i]){const int v=tow_[i];if(v!=fa)dfs1_1(v,u);}}else{for(rg int i=head_[u];i;i=nxt_[i]){const int v=tow_[i];if(v==fa){if(sign[v]){if(vau_[i]<Dis[u]||vau_[i]==Dis[u]&&v<belo[u])belo[u]=v,Dis[u]=vau_[i];}else{if(vau_[i]+Dis[v]<Dis[u]||vau_[i]+Dis[v]==Dis[u]&&belo[v]<belo[u])belo[u]=belo[v],Dis[u]=vau_[i]+Dis[v];}}}for(rg int i=head_[u];i;i=nxt_[i]){const int v=tow_[i];if(v!=fa)dfs1_1(v,u);}} } void dfs2(const int u,const int fa) {if(sign[u]){for(rg int i=head_[u];i;i=nxt_[i]){const int v=tow_[i];if(v!=fa)dfs2(v,u);}}else{ans[u]=0;for(rg int i=head_[u];i;i=nxt_[i]){const int v=tow_[i];if(belo[v]==belo[u]&&Dis[u]>Dis[v]||v==belo[u])continue;rg int p;if(v!=fa)dfs2(v,u);if(belo[v]==belo[u])ans[u]+=ans[v];else if(sign[v]){if(v!=fa){if((Dis[u]+vau_[i])&1)p=check(v,(Dis[u]+vau_[i])/2);else if(v<belo[u])p=check(v,(Dis[u]+vau_[i])/2);else p=check(v,(Dis[u]+vau_[i])/2-1);ans[u]+=size[p];}else{if((Dis[u]+vau_[i])&1)p=check(u,(Dis[u]+vau_[i])/2-Dis[u]);else if(v>belo[u])p=check(u,(Dis[u]+vau_[i])/2-Dis[u]);else p=check(u,(Dis[u]+vau_[i])/2-Dis[u]-1);ans[u]+=n-size[p];}}else{if(v!=fa){if((Dis[u]+Dis[v]+vau_[i])&1)p=check(v,(Dis[u]+Dis[v]+vau_[i])/2-Dis[v]);else if(belo[v]<belo[u])p=check(v,(Dis[u]+Dis[v]+vau_[i])/2-Dis[v]);else p=check(v,(Dis[u]+Dis[v]+vau_[i])/2-Dis[v]-1);ans[u]+=size[p];}else{if((Dis[u]+Dis[v]+vau_[i])&1)p=check(u,(Dis[u]+Dis[v]+vau_[i])/2-Dis[u]);else if(belo[v]>belo[u])p=check(u,(Dis[u]+Dis[v]+vau_[i])/2-Dis[u]);else p=check(u,(Dis[u]+Dis[v]+vau_[i])/2-Dis[u]-1);ans[u]+=n-size[p];}}}for(rg int i=head_[u];i;i=nxt_[i]){const int v=tow_[i];if(belo[v]==belo[u]&&Dis[u]>Dis[v]||v==belo[u])if(v!=fa)dfs2(v,u);}} } void dfs3(const int u,const int fa) {if(sign[u]){ans[u]=n;for(rg int i=head_[u];i;i=nxt_[i]){const int v=tow_[i];rg int p; if(v!=fa)dfs3(v,u);if(belo[v]==u)ans[u]-=ans[v];else if(sign[v]){if(v!=fa){if(vau_[i]&1)p=check(v,vau_[i]/2);else if(v<u)p=check(v,vau_[i]/2);else p=check(v,vau_[i]/2-1);ans[u]-=size[p];}else{if(vau_[i]&1)p=check(u,vau_[i]/2);else if(v>u)p=check(u,vau_[i]/2);else p=check(u,vau_[i]/2-1);ans[u]-=n-size[p];}}else{if(v!=fa){if((Dis[v]+vau_[i])&1)p=check(v,(Dis[v]+vau_[i])/2-Dis[v]);else if(u<belo[v])p=check(v,(Dis[v]+vau_[i])/2-Dis[v]-1);else p=check(v,(Dis[v]+vau_[i])/2-Dis[v]);ans[u]-=size[p];}else{if((Dis[v]+vau_[i])&1)p=check(u,(Dis[v]+vau_[i])/2);else if(u>belo[v])p=check(u,(Dis[v]+vau_[i])/2-1);else p=check(u,(Dis[v]+vau_[i])/2);ans[u]-=n-size[p];}}}}else{for(rg int i=head_[u];i;i=nxt_[i]){const int v=tow_[i];if(v!=fa)dfs3(v,u);}} } void dfs4(const int u,const int fa) {if(sign[u]){for(rg int i=head_[u];i;i=nxt_[i]){const int v=tow_[i];if(v!=fa)dfs4(v,u);}sign[u]=0;}else{for(rg int i=head_[u];i;i=nxt_[i]){const int v=tow_[i];if(v!=fa)dfs4(v,u);}belo[u]=0;}head_[u]=0,Dis[u]=0x7f7f7f7f; } int main() {memset(Dis,0x7f,sizeof(Dis));bit[0]=1;for(rg int i=1;i<=18;i++)bit[i]=bit[i-1]<<1;read(n),s=1;for(rg int i=1;i<n;i++){int u,v;read(u),read(v);addb(u,v),addb(v,u);}who[s][0]=s,dep[s]=1;dfs(s);for(rg int j=1;j<=18;j++)for(rg int i=1;i<=n;i++)who[i][j]=who[who[i][j-1]][j-1],dis[i][j]=dis[i][j-1]+dis[who[i][j-1]][j-1];read(m);for(rg int i=1;i<=m;i++){read(k);for(rg int j=1;j<=k;j++)read(h[j]),qu[j]=h[j],sign[h[j]]=1,Dis[h[j]]=0;std::sort(h+1,h+k+1,cmp);tmp_=0;top=0,stack[++top]=h[1];for(rg int j=2;j<=k;j++){const int LCA=lca(stack[top],h[j]);while(top>1&&dep[stack[top-1]]>dep[LCA]){const int DIS=dist(stack[top-1],stack[top]);addb_(stack[top-1],stack[top],DIS),addb_(stack[top],stack[top-1],DIS);top--;}if(dep[stack[top]]>dep[LCA]){const int DIS=dist(LCA,stack[top]);addb_(LCA,stack[top],DIS),addb_(stack[top],LCA,DIS);top--;}if(!top||dep[stack[top]]<dep[LCA])stack[++top]=LCA;stack[++top]=h[j];}while(top>1){const int DIS=dist(stack[top-1],stack[top]);addb_(stack[top-1],stack[top],DIS),addb_(stack[top],stack[top-1],DIS);top--;}dfs1_0(stack[1],0);dfs1_1(stack[1],0);dfs2(stack[1],0);dfs3(stack[1],0);dfs4(stack[1],0);for(rg int i=1;i<=k;i++)print(ans[qu[i]]),putchar(' ');putchar('\n');}return flush(),0; }

總結(jié)

上面兩道例題差不多覆蓋了差不多虛樹(shù)要用到的所以基礎(chǔ)操作了,總結(jié)一個(gè)虛樹(shù)的板子還是挺好的,虛樹(shù)寫起來(lái)簡(jiǎn)單,也挺好用的,復(fù)雜度也挺優(yōu)秀,值得好好研究一番
update by 2018.3:感謝Michael_Li對(duì)本篇博客的建議與指正
update by 2019.1:對(duì)部分公式進(jìn)行了美化更新

總結(jié)

以上是生活随笔為你收集整理的虚树总结的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問(wèn)題。

如果覺(jué)得生活随笔網(wǎng)站內(nèi)容還不錯(cuò),歡迎將生活随笔推薦給好友。

日日射av | 免费在线一区二区三区 | 久久视频这里有久久精品视频11 | 97色在线视频 | 深爱婷婷网 | 天天艹天天操 | 又爽又黄又无遮挡网站动态图 | 五月婷婷视频在线 | avsex| 中文字幕一区二区三区久久 | 亚洲黄色av网址 | 91精品免费视频 | 黄网站app在线观看免费视频 | 黄www在线观看 | 天天色天天综合 | 国产精品www | a√天堂中文在线 | 免费三级骚 | 午夜久久久久 | 色综合久久综合中文综合网 | 久久,天天综合 | 91在线国产观看 | 精品一区中文字幕 | 欧美午夜寂寞影院 | 亚洲aaa毛片 | 天天插狠狠干 | 能在线观看的日韩av | 久久久久久久久电影 | 在线看黄网站 | 在线 影视 一区 | 中文字幕二区在线观看 | 国产精品久久一 | 久草成人在线 | 色婷婷免费视频 | 美女国产精品 | 丁香婷婷激情啪啪 | 国产群p视频 | 色网站免费在线观看 | 一区二区三区四区不卡 | 亚洲国产免费网站 | 日韩精品中文字幕在线播放 | 国产 日韩 欧美 中文 在线播放 | 久99久在线视频 | 91看片在线| 日日夜夜国产 | 国产一区二区精品91 | 日本免费一二三区 | 精品国产成人在线 | 国产中文字幕在线播放 | 久久国产精品精品国产色婷婷 | 国产视频精品免费播放 | 久久久久久99精品 | 久久激情精品 | 香蕉免费 | 91在线超碰 | 日本韩国精品一区二区在线观看 | 蜜臀久久99静品久久久久久 | 国产成人不卡 | 曰本三级在线 | 婷婷天天色 | 五月婷综合 | 国产午夜精品一区二区三区在线观看 | 亚洲成人精品av | 91精品欧美一区二区三区 | 99热网站| 欧美日韩不卡在线视频 | 亚洲高清色综合 | 欧美日韩在线观看不卡 | 狠狠干夜夜操天天爽 | 国产高清精品在线观看 | 国产九九九精品视频 | 在线免费视频你懂的 | 精品亚洲va在线va天堂资源站 | 日日碰狠狠躁久久躁综合网 | 久久99国产精品 | 超碰在线亚洲 | 91av精品| 91最新网址在线观看 | 国产午夜精品久久久久久久久久 | 日韩高清不卡一区二区三区 | 久久久受www免费人成 | 久操免费视频 | 亚洲欧美成人在线 | 国产一区二区三区免费视频 | 中文字幕在线播放第一页 | 欧美不卡视频在线 | 91成人国产| 九九欧美 | 中文字幕黄色av | 国产精品久久久久久久99 | 欧美不卡视频在线 | 国产在线日本 | 成人欧美日韩国产 | 99re在线视频观看 | 亚洲精品成人av在线 | 九色自拍视频 | 青草视频网 | 久久色网站 | 免费看黄在线观看 | 免费欧美 | 亚洲观看黄色网 | 97电影在线| 18岁免费看片 | 正在播放一区二区 | 久久久久在线 | 欧美色久 | 久久国产精品一区二区三区四区 | 亚洲精品国产片 | 国产片免费在线观看视频 | 激情丁香久久 | 国产在线观看,日本 | 娇妻呻吟一区二区三区 | 久久九九影院 | 精品久久久久久综合 | 国产+日韩欧美 | 黄色小说免费观看 | 激情导航 | 91亚洲精品国偷拍自产在线观看 | 日b视频在线观看网址 | 在线小视频你懂得 | 美女国产在线 | 国产精品123 | 在线视频精品 | 三级在线视频观看 | 在线观看中文字幕 | 麻豆视频观看 | 五月天色综合 | 狠狠色丁香婷婷综合久久片 | 国产欧美三级 | 成人在线视频在线观看 | 黄色一级网 | 欧美美女视频在线观看 | 国产精品18久久久久久不卡孕妇 | 国产麻豆精品久久 | 午夜精品一区二区三区在线观看 | 深夜免费福利视频 | 午夜一级免费电影 | 亚洲观看黄色网 | 久久综合免费 | 日韩av不卡播放 | 免费观看性生交 | 精品国产aⅴ麻豆 | 草久在线播放 | 亚洲成色777777在线观看影院 | 一区二区三区播放 | 色综合天天综合在线视频 | 久草在线网址 | 天堂在线视频免费观看 | 日韩资源在线播放 | 久久免费国产 | 又爽又黄在线观看 | 日韩理论电影在线观看 | 夜夜夜影院 | 91在线视频免费播放 | 18久久久久 | 18久久久久 | 337p日本大胆噜噜噜噜 | www99久久| 毛片网在线播放 | 国产精品久久久久久久久久99 | 波多野结衣理论片 | 久久99精品国产91久久来源 | 国产精品青草综合久久久久99 | 亚洲精品乱码久久久久久 | 中文字幕在线免费看线人 | 超碰人在线| 中文字幕在线播放第一页 | 一区二区久久久久 | 亚洲精品乱码久久久久久蜜桃动漫 | 九九热中文字幕 | 黄色av电影一级片 | 色香com. | 日韩黄色免费在线观看 | 久久 亚洲视频 | 欧美黑人巨大xxxxx | 亚洲午夜精品在线观看 | 蜜臀av麻豆 | 日本最大色倩网站www | 国产99久久99热这里精品5 | 91av精品 | 99中文字幕在线观看 | 91丨精品丨蝌蚪丨白丝jk | 91在线网址| 9在线观看免费高清完整版在线观看明 | 不卡的一区二区三区 | 狠狠精品| 成人av免费播放 | 日韩av电影中文字幕 | 午夜精品电影 | 青青河边草观看完整版高清 | 亚洲视屏在线播放 | 欧美日韩一区二区免费在线观看 | 99久久精品国产亚洲 | 在线免费观看国产 | 丰满少妇在线观看网站 | 日韩av一区在线观看 | 天天色天天爱天天射综合 | 久久精品国产99国产 | 免费黄色在线播放 | 在线观看亚洲专区 | a在线播放 | 国产一区视频在线 | 九九影视理伦片 | 欧美日韩高清一区二区 | 久久综合久色欧美综合狠狠 | 91av中文| 91人人爱| 国产视频一区二区在线 | 我要看黄色一级片 | 天天操比 | 日韩在线精品一区 | 精品久久久亚洲 | 亚洲欧洲成人精品av97 | 99久久99视频 | 国产视频精品久久 | 久久成人国产 | 国内外激情视频 | 久久久免费看视频 | 免费网址你懂的 | 99视频在线观看视频 | 国产高清视频免费观看 | 99av在线视频| 夜夜干天天操 | 久久久久久免费网 | 久久精品视频免费观看 | 成人免费xxxxxx视频 | 99精品在线视频观看 | 国产人在线成免费视频 | 色婷五月 | 国产精品免费在线播放 | 欧美一级电影免费观看 | 99色在线观看视频 | a黄在线观看 | 亚洲欧美成人 | 日本黄色免费大片 | 日本精品一区二区三区在线观看 | 国产视频在线观看一区二区 | 日韩欧美精品在线观看视频 | 日日操天天操夜夜操 | www.久久色.com | 狠狠狠色丁香综合久久天下网 | 粉嫩aⅴ一区二区三区 | 成人午夜精品 | 国产精品高潮久久av | 国产女做a爱免费视频 | 一区av在线播放 | 久久av中文字幕片 | 五月开心色 | 亚洲综合丁香 | 久久精品看片 | 99热免费在线 | 中国一级片在线观看 | 久久亚洲精品电影 | 天天干天天看 | 国产高清在线视频 | 8x8x在线观看视频 | 日韩电影中文字幕 | 天天弄天天干 | 三级a视频 | 精品国产乱码久久久久久浪潮 | 一区二区精品久久 | 在线黄色国产 | 91大神精品视频在线观看 | 日韩va欧美va亚洲va久久 | 国产午夜三级 | 高清免费在线视频 | 欧美日本不卡高清 | 狠狠躁日日躁狂躁夜夜躁 | 91香蕉亚洲精品 | 五月天综合色 | 日韩国产精品毛片 | 免费看的黄网站 | 日韩一级片观看 | 欧美性性网 | 久久婷亚洲五月一区天天躁 | 日本在线观看视频一区 | 国产日韩在线播放 | 日本精品一区二区三区在线观看 | 黄色网在线播放 | 精品影院一区二区久久久 | 久久香蕉国产精品麻豆粉嫩av | 99久久夜色精品国产亚洲 | 在线超碰av | 亚洲女人天堂成人av在线 | 六月丁香激情综合 | av怡红院 | 久久天天综合网 | 国产黄色大片免费看 | av在线一二三区 | 日韩二区在线观看 | 国产成人精品免高潮在线观看 | 欧美日韩国产一区二区在线观看 | 免费一级特黄毛大片 | 在线观看的av网站 | 久久精品中文字幕少妇 | 亚洲一区免费在线 | 欧美一区二区免费在线观看 | 亚洲欧洲国产日韩精品 | 免费观看性生交 | av亚洲产国偷v产偷v自拍小说 | 天天综合成人网 | 亚洲不卡123 | 色婷婷激情电影 | 欧美精品久久 | 五月天堂色 | 五月天激情视频 | 最近2019年日本中文免费字幕 | 国产免费专区 | 国产乱对白刺激视频不卡 | 麻豆国产精品永久免费视频 | 久久国产精品视频观看 | 日韩免费在线一区 | 日韩激情在线视频 | 一区二区久久久久 | 久久好看免费视频 | 国产在线理论片 | av在线播放中文字幕 | 在线视频欧美日韩 | 中文字幕日韩有码 | 久久这里有精品 | 国产精品久久久久久久久婷婷 | 国产一区二区在线免费 | 91av在线播放视频 | 免费无遮挡动漫网站 | 91亚洲精品久久久 | 国产精品久久久久久久久久久久久久 | 911精品美国片911久久久 | 在线国产不卡 | 特级西西www44高清大胆图片 | 欧美a性| 精品久久久久久亚洲综合网 | 日本午夜在线观看 | 99久久久国产精品美女 | 欧美伦理一区二区三区 | 91成人国产 | 在线视频欧美精品 | 欧美精品在线观看 | 免费成人黄色片 | 国产亚洲综合精品 | 亚洲精品美女免费 | 国产一区二区精品久久 | 国产精品美女久久久免费 | 国产a视频免费观看 | 久久久在线免费观看 | 久久久久久久久久国产精品 | 国产一级免费在线 | 久久久999免费视频 日韩网站在线 | 91成人在线观看喷潮 | 精品国产区 | 亚洲欧美日韩国产精品一区午夜 | 国产精品va在线 | 成人av高清在线观看 | 日本精品视频在线观看 | 国产成人精品一区一区一区 | 精品美女久久久久久免费 | 97**国产露脸精品国产 | www在线免费观看 | 日一日操一操 | 久久国产精品影视 | 色综合久 | 亚洲激情国产精品 | 日韩激情视频在线观看 | 中文字幕色在线视频 | 日韩一级理论片 | 极品久久久久久久 | 亚洲va欧洲va国产va不卡 | 色婷婷av一区二 | 在线观看黄色国产 | 欧美a视频在线观看 | 亚洲成人av片在线观看 | 国产传媒中文字幕 | 亚洲精品视频在线观看免费视频 | 国产精品黑丝在线观看 | 美女视频黄是免费的 | 9999在线视频 | 色欲综合视频天天天 | 99高清视频有精品视频 | 91免费版在线观看 | 夜色资源网 | 日韩天堂在线观看 | 国产精品尤物 | 日日碰狠狠添天天爽超碰97久久 | 久久久精品高清 | 狠狠躁天天躁 | 欧美精品小视频 | 99热手机在线观看 | 超碰人人91 | 久久精品女人毛片国产 | 日本资源中文字幕在线 | 亚洲视屏 | 亚洲最新视频在线播放 | 欧美成亚洲| 狠狠干狠狠操 | 日本中文字幕网站 | 日韩欧美在线免费 | 国产成人精品免高潮在线观看 | 天天干天天干天天干天天干天天干天天干 | 蜜臀av性久久久久蜜臀aⅴ四虎 | 色美女在线 | 国产精品乱码一区二区视频 | 久久久蜜桃一区二区 | 久久96国产精品久久99软件 | 欧美在线观看小视频 | 91精品国自产在线 | 在线观看黄网 | 亚洲午夜精品久久久 | 五月天婷婷视频 | 亚洲最新视频在线播放 | 国产在线污 | 97**国产露脸精品国产 | 在线欧美中文字幕 | 久久的色 | 99在线热播 | 综合久久久久久久 | 国产高清不卡 | 日韩三级成人 | 黄色小说在线免费观看 | 色综合久久精品 | 久久国产精品久久精品 | sesese图片| 色91在线 | 色婷婷久久久综合中文字幕 | 国产精品一区二区三区免费看 | 激情av资源 | 久久伦理网 | 人人草在线视频 | 日韩欧美视频一区二区三区 | 欧美日韩中文字幕在线视频 | 99在线视频免费观看 | 久草在线高清 | 久久久免费在线观看 | 日本久热 | 欧美日韩在线观看一区二区 | 99久久精品国产毛片 | 国产免费观看av | 中文字字幕在线 | 天天躁日日躁狠狠躁av麻豆 | 在线观看岛国片 | 精品视频亚洲 | 97视频在线观看网址 | 日韩激情在线视频 | 开心色停停| 国产高清成人av | 成年免费在线视频 | 99精品国产一区二区三区不卡 | 成人午夜影院在线观看 | 夜夜摸夜夜爽 | 日韩videos| 久99久久 | 日韩在线视频观看免费 | 久久精品999 | 日韩免费中文字幕 | 久久99精品国产99久久6尤 | 日韩在线免费高清视频 | 午夜精品一区二区三区在线观看 | 青青久草在线视频 | 午夜精品一区二区三区免费视频 | 正在播放国产精品 | 亚洲一区黄色 | 国产成人免费观看久久久 | 免费a级观看| 免费观看完整版无人区 | 精品国产伦一区二区三区观看方式 | 色婷婷婷 | 久久久久看片 | 蜜臀aⅴ国产精品久久久国产 | 国产精品一区二区吃奶在线观看 | 国产麻豆剧果冻传媒视频播放量 | 国产一区二区日本 | 日本黄区免费视频观看 | 国产美女免费 | 亚洲精品五月 | 五月婷婷,六月丁香 | 日韩精品欧美专区 | 久久夜色网 | 成人av在线电影 | 久久激情五月激情 | 亚洲成人软件 | 四虎影视成人精品 | 日韩av免费在线电影 | 国产精品亚洲a | 亚洲闷骚少妇在线观看网站 | 欧美一区二区三区激情视频 | 亚洲精品456在线播放乱码 | 九草视频在线观看 | 久久久99国产精品免费 | 射综合网| 国产精品久久久久久高潮 | 日韩av不卡在线 | 亚洲成人av电影 | 色婷婷一区 | 手机色在线 | 超碰在线人人艹 | 91精品在线播放 | 成年人网站免费观看 | 国产69久久久欧美一级 | 国产精品久久三 | 在线国产专区 | 欧美色图东方 | 中文字幕在线观看视频网站 | 久久精品国产亚洲精品2020 | av在线免费网站 | av中文在线影视 | 成人久久毛片 | 国产色拍拍拍拍在线精品 | 免费a视频在线观看 | 国产区精品视频 | 有码中文字幕在线观看 | 亚洲精品国产综合99久久夜夜嗨 | 国产黄色精品在线 | 午夜视频在线观看网站 | 久久噜噜少妇网站 | 久久免费激情视频 | 国产探花视频在线播放 | 久久久久久激情 | 久久夜色精品国产欧美一区麻豆 | 日韩三级一区 | 日韩美av在线 | 狠狠色丁香婷婷综合久久片 | 亚洲 欧美变态 另类 综合 | 免费观看成人网 | 超碰在线9 | av免费在线观| 成人免费视频视频在线观看 免费 | 国产精品自在线 | 亚洲理论电影 | 91亚色视频在线观看 | 欧美日韩高清一区二区 国产亚洲免费看 | 久久久久伊人 | 日韩电影在线一区二区 | 久久精品免视看 | 香蕉视频在线免费 | 人人模人人爽 | 国产精品 日韩精品 | 久久婷亚洲五月一区天天躁 | 99精品国产福利在线观看免费 | 国产一区二区成人 | 日韩欧美视频免费在线观看 | 日日夜夜天天人人 | 欧美成人区 | 亚洲www天堂com | 国产中文字幕精品 | 婷婷四房综合激情五月 | 精品国产观看 | bayu135国产精品视频 | 国产热re99久久6国产精品 | 精品久久久久久国产91 | 97在线观看免费视频 | 久草视频在线免费 | 视频 国产区 | 久久99精品国产麻豆宅宅 | 波多野结衣动态图 | 在线视频婷婷 | 国产亚洲欧美在线视频 | 婷婷丁香狠狠爱 | 人人插人人舔 | 黄色av免费| 最近中文字幕国语免费高清6 | av中文字幕日韩 | 婷婷综合电影 | 精品一区在线看 | 久久久天天操 | 国产一区在线看 | 国产精品免费麻豆入口 | 激情网五月天 | 日本成址在线观看 | 成人免费观看完整版电影 | 午夜免费久久看 | 欧美精品久久 | www.福利视频 | 久久久精品小视频 | 国产粉嫩在线观看 | 欧美激情视频在线观看免费 | 五月天丁香综合 | 亚洲欧洲日韩 | 99久久9 | 国产在线观看污片 | 成人av电影免费在线播放 | 亚洲高清国产视频 | 久久久国产99久久国产一 | 波多野结衣在线中文字幕 | 久久久久这里只有精品 | 天天天干天天射天天天操 | 国产亚洲精品久久 | 毛片永久新网址首页 | 色网址99| 久久好看| 精品在线视频一区二区三区 | 国产精品资源在线观看 | 日韩欧美在线一区二区 | 久九视频 | a在线一区 | 91视视频在线直接观看在线看网页在线看 | 久草在线免费电影 | 国产日韩在线观看一区 | 中文字幕一区二区三区久久蜜桃 | 日本 在线 视频 中文 有码 | 国产小视频免费在线观看 | av大全免费在线观看 | 美女视频黄在线 | 成人国产精品久久久久久亚洲 | 日韩免费观看av | 亚洲欧美偷拍另类 | 国产91在线观看 | 国产高清中文字幕 | 国产做aⅴ在线视频播放 | 国产成人精品av在线观 | 91麻豆看国产在线紧急地址 | 69av在线播放 | 日韩a在线看| 亚洲色图av | 99久久综合国产精品二区 | 久久一区91| 久久国产精品影视 | 欧美成人h版在线观看 | 国产精品18久久久久久久网站 | 亚洲成av人影院 | 麻豆一区在线观看 | 91亚洲精品乱码久久久久久蜜桃 | 又黄又爽又色无遮挡免费 | ww亚洲ww亚在线观看 | 99久久精品国产观看 | 激情开心| 香蕉视频91 | 欧美色图视频一区 | 日韩电影一区二区在线 | 久久99精品久久只有精品 | 91九色视频在线播放 | 色综合天天综合网国产成人网 | 亚洲国产精品激情在线观看 | 久久夜色电影 | 久久精品看 | 干狠狠| 久久经典国产视频 | 欧美日韩国产在线 | .国产精品成人自产拍在线观看6 | 麻豆视频在线免费观看 | 中文字幕久久精品亚洲乱码 | 久久免费视频99 | 黄色电影在线免费观看 | 黄色免费电影网站 | 91视频免费网址 | 精品久久99 | 日韩av中文字幕在线免费观看 | 高清不卡免费视频 | 精品电影一区 | 久久中文网 | 亚洲综合色激情五月 | 国产精品久久久久久久免费 | 激情婷婷色| 成人在线视频免费观看 | 国产精久久久久久妇女av | 色综合天天天天做夜夜夜夜做 | 狠狠躁天天躁综合网 | 欧美精品视 | 日韩中文在线电影 | www.亚洲在线 | 日韩免费电影一区二区 | 97香蕉久久国产在线观看 | 亚洲情婷婷 | 婷婷久久网 | 麻豆91精品视频 | 超碰免费公开 | 色网站国产精品 | www.福利| 精品国产aⅴ麻豆 | 国内精品久久久久久 | 久久精品久久99 | 免费观看特级毛片 | 2021国产精品 | 国产精品久久久久影院 | 国产亚洲欧美日韩高清 | 精品国产一区二区三区久久影院 | 国产精品久久三 | 中文超碰字幕 | www.国产在线 | 激情五月av | 91麻豆精品国产自产在线 | 在线视频国产区 | 2000xxx影视| 国产v视频| 欧亚日韩精品一区二区在线 | 亚洲免费av网站 | 久久国产精品视频 | 亚洲成aⅴ人片久久青草影院 | 国产精品一区二区三区免费视频 | 国产精品123 | 国产小视频网站 | 国产 欧美 日韩 | 黄色毛片视频免费 | 国产精品成久久久久三级 | 色资源中文字幕 | 国产精品国产自产拍高清av | 色www永久免费 | 波多野结衣视频一区 | 久在线观看 | 成人在线观看资源 | 中文字幕乱码电影 | 久久精国产 | 在线免费观看黄色 | 色婷婷99| 在线观看mv的中文字幕网站 | 欧美精品免费在线观看 | 日韩综合一区二区 | 天天干天天草 | 激情综合网在线观看 | 国产亚洲一区二区在线观看 | 99这里只有精品99 | 一级一级一片免费 | 毛片888| 久久人人爽人人爽人人片av软件 | 久久久久欧美精品999 | 日韩精品一区二区在线 | 99视频+国产日韩欧美 | 91看国产| 五月天婷婷在线播放 | 国产精品久久久久永久免费观看 | 色婷婷午夜 | 韩国av免费在线 | 亚洲日本中文字幕在线观看 | 人人爽人人爽av | 日本三级香港三级人妇99 | 国产精品麻豆一区二区三区 | 日韩av电影一区 | 国产精品日韩在线 | 天天射网| 精品一区二区免费在线观看 | 久久免费视频8 | 婷婷天天色 | 激情丁香月 | 狠狠色丁香婷婷综合久久片 | 中文字幕成人在线观看 | 91麻豆精品国产91久久久更新时间 | 国产精品久久久久久久久久久免费 | 探花视频网站 | 婷婷六月综合亚洲 | 五月天免费网站 | 亚洲欧美国产精品va在线观看 | 色香com. | 国产精品美女久久久久久2018 | av免费电影在线 | 亚洲1级片| 精品国产一区二区三区蜜臀 | 国产精品入口传媒 | 免费国产一区二区视频 | 亚洲欧美国产视频 | 日韩色高清 | 久久影院亚洲 | 亚洲精品视频网站在线观看 | 在线免费观看黄色小说 | 精品视频9999 | 在线观看免费视频 | 午夜久久福利 | 视频国产在线观看18 | 精品久久久久久久久久久久久久久久久久 | 在线观看中文字幕亚洲 | 黄色网址a | 超薄丝袜一二三区 | 日本在线成人 | 亚洲成av片人久久久 | 成人黄色片在线播放 | 国产中文字幕免费 | av午夜电影 | 狠狠躁夜夜躁人人爽视频 | 久久久久久久久久网站 | 欧美成人69av | 91伊人| 麻豆精品传媒视频 | 人人爱天天操 | 999国内精品永久免费视频 | 久久久久综合视频 | 亚洲综合欧美日韩狠狠色 | 亚洲在线视频观看 | 插综合网 | 黄色小视频在线观看免费 | 在线免费观看国产黄色 | 国产成人av电影在线 | 国产高清无av久久 | 青青啪 | 久久久久久久久久久网站 | 国产黄色电影 | 白丝av在线| 9在线观看免费 | 色综合激情网 | 国产视频九色蝌蚪 | www.久久视频 | 亚洲视频网站在线观看 | 亚洲成人精品在线观看 | 色婷婷啪啪免费在线电影观看 | 久久大片网站 | 亚洲免费小视频 | 日韩videos | 91成人天堂久久成人 | av不卡中文字幕 | 最新av在线网址 | 天天操比 | 亚洲高清在线视频 | 国产欧美在线一区 | 99精品欧美一区二区三区 | 亚洲精品人人 | 国产电影黄色av | 五月天综合婷婷 | 99热.com| 五月激情综合婷婷 | 久久一久久 | 999精品视频 | av片子在线观看 | 色综合天天视频在线观看 | 天天夜夜狠狠操 | 久久99精品热在线观看 | 久久精品视频网 | 久久99精品久久久久久久久久久久 | 一区二区三区在线不卡 | av中文字幕在线免费观看 | 国产精品成人国产乱 | 成人国产在线 | 精品国产美女在线 | 一本一本久久a久久 | 色五婷婷 | 日韩精品久久久久 | 日本护士三级少妇三级999 | 久久综合成人 | 国产成人一区二区在线观看 | 在线视频你懂 | 精品在线观看视频 | 国产黄a三级三级 | 亚洲播放一区 | 精品国产一区二区三区蜜臀 | 狠狠狠综合 | 国产精品久久久久久久久岛 | 久久激情综合 | 国产精品18久久久久久久久 | 91精品国产综合久久福利 | 激情片av| 最新中文字幕视频 | 精品日韩在线一区 | 日韩中字在线观看 | 99国内精品久久久久久久 | 国产精品免费不 | 亚洲综合五月 | 久久久福利| 久热电影 | 中文字幕第一页在线视频 | 特黄一级毛片 | 中文网丁香综合网 | 久久久久久久久久久久久久免费看 | 天天摸天天干天天操天天射 | 亚洲91网站| 97视频免费播放 | 视频1区2区| 中文字幕国产精品一区二区 | 国产精品美女久久久久久2018 | 久久免费视频6 | 二区三区在线视频 | 国产在线视频不卡 | 国产精品一区二区av影院萌芽 | 国产在线观看国语版免费 | 91成人在线免费观看 | 天天摸日日摸人人看 | 99精品乱码国产在线观看 | 免费一级日韩欧美性大片 | 97在线观看免费高清完整版在线观看 | 久久久久久久久黄色 | 国产精品18videosex性欧美 | 久草在线费播放视频 | 欧美一区中文字幕 | 久久精品久久综合 | 黄色片网站免费 | 中文字幕精品三区 | 五月婷婷在线综合 | 国内免费久久久久久久久久久 | 国产无套一区二区三区久久 | 久久久私人影院 | 欧美福利网址 | 999久久精品| 精品国产乱码一区二区三区在线 | 91精品成人久久 | 丁香九月激情 | 91伊人影院 | 久久久国产精品网站 | 久久精品国产一区二区三 | 亚洲1级片 | 午夜在线观看一区 | 蜜臀av性久久久久蜜臀av | 麻豆一区二区 | 成年人精品 | 久草在线视频资源 | 91麻豆精品国产 | 国产在线观看一 | 美国av大片 | www.久热 | 久久精品日韩 | 91精品在线视频观看 | 亚洲一区二区三区在线看 | 国产在线一卡 | 国产精品久久久久久久久久妇女 | 午夜精品福利影院 | 成年人国产精品 | 日韩中文字幕免费视频 | 日本精品视频在线观看 | 国产中文字幕网 | 久久久综合九色合综国产精品 | 亚洲激情在线播放 | 国产手机视频精品 | 亚洲精品美女在线观看播放 | 93久久精品日日躁夜夜躁欧美 | 久久影视精品 | 日日天天干 | 亚欧日韩成人h片 | 成人av网站在线播放 | 美女av免费 | 特级西西444www大精品视频免费看 | 中字幕视频在线永久在线观看免费 | 天天干夜夜夜操天 | 国产中文在线播放 | 国产精品成人aaaaa网站 | 天天艹天天干天天 | 色网站免费在线观看 | 欧美日本国产在线观看 | 亚洲精品国产拍在线 | 久久99精品国产99久久6尤 | a在线观看免费视频 | 国产字幕在线看 | 久草在线资源免费 | 91中文字幕网 | 国产裸体永久免费视频网站 | 久久久99国产精品免费 | 亚洲情感电影大片 | a久久免费视频 | 国产精品99久久久久久久久 | 婷婷六月中文字幕 | 精品视频免费播放 | 成人cosplay福利网站 | 五月天激情综合 | 国产伦精品一区二区三区… | 黄色资源在线观看 | 日韩免费高清在线观看 | 久草在线精品观看 | 久久网站av | 国产无吗一区二区三区在线欢 | 男女免费视频观看 | 不卡电影一区二区三区 | 日韩精品一区二区久久 | 色综合天天色综合 | 91成版人在线观看入口 | 国产小视频在线免费观看 | 精品黄色在线 | 亚洲精品乱码久久久久久写真 | 精品一二三四五区 | 91高清免费 | 久久系列 | 一区中文字幕电影 | 又色又爽又黄 | 亚洲精品视频久久 | 韩国精品一区二区三区六区色诱 | 国产成人精品av | 91视频com | 亚洲国产一区二区精品专区 | 亚洲精品乱码久久久久久高潮 | 免费观看久久久 | 色www免费视频 | 99在线视频网站 | 久久国产剧场电影 | 91视频传媒| 成年人视频在线观看免费 | 国产精品久久久久久99 | 久久视频免费在线 | 成人h视频在线 | 狠狠躁日日躁狂躁夜夜躁av | 超碰97免费 | 日本乱码在线 | 干天天| 日韩欧美精品在线视频 | 中文字幕中文 | 超碰在线人人爱 | 精品999| 狠狠操电影网 | 97超碰色偷偷 | 日韩电影在线观看一区二区三区 | 夜夜夜影院| 免费黄色网址网站 | 久久免费看av| 色操插 | 日韩高清免费观看 | 黄色av成人在线 | www.狠狠操.com | 91精品久久香蕉国产线看观看 | 91色吧 | 天天操天天干天天爽 | 欧美色综合天天久久综合精品 | 中文字幕在线视频免费播放 | 精品国产伦一区二区三区观看说明 | 免费在线激情电影 | 国产视频18 | 91在线公开视频 | 午夜久久美女 | 国产精品色视频 | 久久精品com |