久久精品国产精品国产精品污,男人扒开添女人下部免费视频,一级国产69式性姿势免费视频,夜鲁夜鲁很鲁在线视频 视频,欧美丰满少妇一区二区三区,国产偷国产偷亚洲高清人乐享,中文 在线 日韩 亚洲 欧美,熟妇人妻无乱码中文字幕真矢织江,一区二区三区人妻制服国产

歡迎訪問 生活随笔!

生活随笔

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

编程问答

树形DP 学习总结

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

DP畢竟是算法中最精妙的部分,理解并玩得花哨還是需要一定的時(shí)間積累

之前對(duì)普通的DP也不敢說掌握,只能說略懂皮毛

在學(xué)習(xí)樹形DP 的同時(shí)也算是對(duì)DP有了更深的理解吧

DP的關(guān)鍵就在于狀態(tài)的定義以及找轉(zhuǎn)移

首先要考慮清楚狀態(tài),狀態(tài)要能夠很好地并且完整地描述子問題

其次考慮最底層的狀態(tài),這些狀態(tài)一般是最簡單的情況或者是邊界情況

再就是考慮某一個(gè)狀態(tài)能從哪些子狀態(tài)轉(zhuǎn)移過來,同時(shí)還要考慮轉(zhuǎn)移的順序,確保子問題已經(jīng)解決

樹形DP很多時(shí)候就是通過子節(jié)點(diǎn)推父親節(jié)點(diǎn)的狀態(tài)

還是通過題目來加強(qiáng)理解吧

1.HDU 1520

題意:給一棵樹,選最多的結(jié)點(diǎn)使得選擇的結(jié)點(diǎn)不存在直接的父子關(guān)系

很容易想到一個(gè)結(jié)點(diǎn)有兩個(gè)狀態(tài):選或者不選

所以自然地想到狀態(tài)dp[u][0/1]表示u子樹內(nèi)的最佳答案,u的狀態(tài)為選或者不選

初始化自然是葉子結(jié)點(diǎn)dp[u][0]=0,dp[u][1]=w[u]

轉(zhuǎn)移則可以考慮依次考慮

u不選的時(shí)候:u的兒子可以任意選或者不選,所以dp[u][0]+=max(dp[v][0],dp[v][1])

u選的時(shí)候:u的兒子必定不能選,所以dp[u][1]+=dp[v][0] ? 然后dp[u][1]+=w[u]表示加上u這個(gè)點(diǎn)

答案自然就是max(dp[rt][0],dp[rt][1])了

#include"cstdio" #include"queue" #include"cmath" #include"stack" #include"iostream" #include"algorithm" #include"cstring" #include"queue" #include"map" #include"set" #include"vector" #include"bitset" #define LL long long #define ull unsigned long long #define mems(a,b) memset(a,b,sizeof(a)) #define mdzz int mid=(L+R)>>1 #pragma comment(linker, "/STACK:1024000000,1024000000") using namespace std;const int N = 6005; const int M = 1e5+5; const int MOD = 998244353; const int INF = 0x3f3f3f3f;int tot; int first[N],w[N],deg[N]; int dp[N][2];struct node{int e,next;node(){}node(int a,int b):e(a),next(b){} }edge[M];void init(){tot=0;mems(first,-1);mems(deg,0);mems(dp,0); }void addedge(int u,int v){edge[tot]=node(v,first[u]);first[u]=tot++; }void dfs(int u){dp[u][0]=0;dp[u][1]=w[u];for(int i=first[u];i!=-1;i=edge[i].next){int v=edge[i].e;dfs(v);dp[u][0]+=max(dp[v][1],dp[v][0]);dp[u][1]+=dp[v][0];} } int n; int main(){//freopen("in.txt","r",stdin);while(~scanf("%d",&n)){init();for(int i=1;i<=n;i++) scanf("%d",&w[i]);int u,v;while(1){scanf("%d%d",&v,&u);if(!v&&!u) break;addedge(u,v);deg[v]++;}int rt;for(int i=1;i<=n;i++) if(!deg[i]){dfs(rt=i);break;}printf("%d\n",max(dp[rt][0],dp[rt][1]));}return 0; } View Code

2.POJ 1436

題意:選中一個(gè)點(diǎn)則與其相連的邊將被覆蓋,問最少選幾個(gè)點(diǎn)使得樹中所有邊均被覆蓋

和上一個(gè)題很類似

同樣狀態(tài)設(shè)為dp[u][0/1]

初始的底層狀態(tài)自然是dp[u][0]=0,dp[u][1]=1;

考慮一個(gè)非葉子結(jié)點(diǎn)和它兒子的所有連邊

如果當(dāng)前結(jié)點(diǎn)不選,那這些邊只能由其兒子保護(hù),所以dp[u][0]+=dp[v][1]

如果當(dāng)前結(jié)點(diǎn)選,那這些邊已被保護(hù),其兒子選和不選都行,所以dp[u][1]+=min(dp[v][0],dp[v][1])

答案自然是min(dp[rt][0],dp[rt][1])

#include"cstdio" #include"queue" #include"cmath" #include"stack" #include"iostream" #include"algorithm" #include"cstring" #include"queue" #include"map" #include"set" #include"vector" #include"bitset" #define LL long long #define ull unsigned long long #define mems(a,b) memset(a,b,sizeof(a)) #define mdzz int mid=(L+R)>>1 #pragma comment(linker, "/STACK:1024000000,1024000000") using namespace std;const int N = 1505; const int M = 1e5+5; const int MOD = 998244353; const int INF = 0x3f3f3f3f;int tot; int first[N],deg[N]; int dp[N][2];struct node{int e,next;node(){}node(int a,int b):e(a),next(b){} }edge[M];void init(){tot=0;mems(first,-1);mems(deg,0); }void addedge(int u,int v){edge[tot]=node(v,first[u]);first[u]=tot++; }void dfs(int u){dp[u][0]=0;dp[u][1]=1;for(int i=first[u];i!=-1;i=edge[i].next){int v=edge[i].e;dfs(v);dp[u][0]+=dp[v][1];dp[u][1]+=min(dp[v][0],dp[v][1]);} }int n,k,u,v; int main(){//freopen("in.txt","r",stdin);while(~scanf("%d",&n)){init();for(int i=1;i<=n;i++){scanf("%d:(%d)",&u,&k);for(int j=0;j<k;j++){scanf("%d",&v);addedge(u,v);deg[v]++;}}int rt;for(int i=0;i<n;i++) if(!deg[i]){dfs(rt=i);break;}printf("%d\n",min(dp[rt][0],dp[rt][1]));}return 0; } View Code

3.URAL 1018

題意:樹中每個(gè)點(diǎn)有權(quán)值,問只留下k個(gè)點(diǎn)剩下的最大權(quán)值和是多少?留下的點(diǎn)還是構(gòu)成一棵樹

樹形背包

狀態(tài)定義成dp[u][i]表示u子樹內(nèi)剩i個(gè)點(diǎn)的最大權(quán)值

考慮葉子結(jié)點(diǎn):dp[u][0]=0,dp[u][1]=w[u]

考慮非葉子結(jié)點(diǎn)的一個(gè)狀態(tài)dp[u][i],對(duì)于當(dāng)前的一個(gè)兒子v,枚舉一個(gè)k表示從這個(gè)兒子里取幾個(gè)結(jié)點(diǎn),維護(hù)一個(gè)最大值

其實(shí)我們這里的狀態(tài)是三維的,表示u子樹的前j個(gè)子樹取了i個(gè)結(jié)點(diǎn)的答案

我們使用滾動(dòng)數(shù)組把j這一維滾掉

這里簡化了題目,每一個(gè)結(jié)點(diǎn)固定只有兩個(gè)兒子,用一般做法做肯定也是沒問題的

還有要注意的地方就是這里根是一定要保留的

處理方法就是對(duì)于狀態(tài)dp[u][1]直接賦值,枚舉時(shí)候i從2開始,這樣就可以默認(rèn)根已取

#include"cstdio" #include"queue" #include"cmath" #include"stack" #include"iostream" #include"algorithm" #include"cstring" #include"queue" #include"map" #include"set" #include"vector" #include"bitset" #define LL long long #define ull unsigned long long #define mems(a,b) memset(a,b,sizeof(a)) #define mdzz int mid=(L+R)>>1 #pragma comment(linker, "/STACK:1024000000,1024000000") using namespace std;const int N = 105; const int M = 1e5+5; const int MOD = 998244353; const int INF = 0x3f3f3f3f;int tot; int first[N],w[N]; int dp[N][N],sz[N]; int ls[N],rs[N];struct node{int e,next;node(){}node(int a,int b):e(a),next(b){} }edge[M];void init(){tot=0;mems(first,-1);mems(w,-1);//mems(deg,0);mems(dp,0);mems(ls,-1);mems(rs,-1); }void addedge(int u,int v){edge[tot]=node(v,first[u]);first[u]=tot++;edge[tot]=node(u,first[v]);first[v]=tot++; }void dfs1(int u,int fa){sz[u]=1;for(int i=first[u];i!=-1;i=edge[i].next){int v=edge[i].e;if(v==fa) continue;dfs1(v,u);sz[u]+=sz[v];if(ls[u]==-1) ls[u]=v;else rs[u]=v;} }void dfs(int u){int f=0;dp[u][0]=0;dp[u][1]=w[u];if(ls[u]!=-1) dfs(ls[u]),f=1;if(rs[u]!=-1) dfs(rs[u]),f=1;if(!f) return;for(int i=2;i<=sz[u];i++)for(int j=0;j<=sz[ls[u]];j++) if(i-1>=j) dp[u][i]=max(dp[u][i],dp[ls[u]][j]+dp[rs[u]][i-1-j]+w[u]); }int n,k;int main(){//freopen("in.txt","r",stdin);while(~scanf("%d%d",&n,&k)){init();int u,v,x,rt=1;w[rt]=0;for(int i=1;i<n;i++){scanf("%d%d%d",&u,&v,&x);addedge(u,v);if(w[v]==-1) w[v]=x;else w[u]=x;}dfs1(rt,-1);dfs(rt);printf("%d\n",dp[rt][k+1]);}return 0; } View Code

4.HDU 2196

題意:對(duì)于樹中的每一個(gè)結(jié)點(diǎn),輸出樹中與其距離最遠(yuǎn)的結(jié)點(diǎn)的距離值

經(jīng)典的樹形DP問題

狀態(tài)定義為dp[u][0/1]為u到其子樹內(nèi)結(jié)點(diǎn)的最遠(yuǎn)距離、次遠(yuǎn)距離

這樣一輪dp下來,可以想到對(duì)于根來說,dp[rt][0]就是它的答案

但是對(duì)于其它結(jié)點(diǎn)來說只得到了其子樹內(nèi)的答案,而我們需要的是其對(duì)于整棵樹的信息

這里需要再一次dfs,相當(dāng)于反過來從根往葉子再dp一次,通過根的答案推其余結(jié)點(diǎn)的答案

這里之所以要維護(hù)一個(gè)次大值,就是對(duì)于一個(gè)結(jié)點(diǎn)u的兒子v,

若u的最遠(yuǎn)距離是經(jīng)過u的,那v的答案應(yīng)該是v子樹內(nèi)的答案和u的次大值比較,否則v的答案和u的最大值比較

畫個(gè)圖就明白了

#include"cstdio" #include"queue" #include"cmath" #include"stack" #include"iostream" #include"algorithm" #include"cstring" #include"queue" #include"map" #include"set" #include"vector" #include"bitset" #define LL long long #define ull unsigned long long #define mems(a,b) memset(a,b,sizeof(a)) #define mdzz int mid=(L+R)>>1 #pragma comment(linker, "/STACK:1024000000,1024000000") using namespace std;const int N = 1e4+5; const int M = 2e4+5; const int MOD = 998244353; const int INF = 0x3f3f3f3f;int tot; int first[N]; int mx[N][2],id[N][2];struct node{int e,next,w;node(){}node(int a,int b,int c):e(a),next(b),w(c){} }edge[M];void init(){tot=0;mems(first,-1);mems(mx,0);mems(id,-1); }void addedge(int u,int v,int w){edge[tot]=node(v,first[u],w);first[u]=tot++;edge[tot]=node(u,first[v],w);first[v]=tot++; }void dfs1(int u,int fa){for(int i=first[u];i!=-1;i=edge[i].next){int v=edge[i].e;if(v==fa) continue;dfs1(v,u);if(mx[v][0]+edge[i].w>=mx[u][0]){mx[u][1]=mx[u][0];id[u][1]=id[u][0];id[u][0]=v;mx[u][0]=mx[v][0]+edge[i].w;}else if(mx[v][0]+edge[i].w>mx[u][1]) mx[u][1]=mx[v][0]+edge[i].w,id[u][1]=v;} }void dfs2(int u,int fa){for(int i=first[u];i!=-1;i=edge[i].next){int v=edge[i].e;if(v==fa) continue;if(id[u][0]==v){if(mx[v][1]<mx[u][1]+edge[i].w){mx[v][1]=mx[u][1]+edge[i].w;id[v][1]=u;}}else{if(mx[v][1]<mx[u][0]+edge[i].w){mx[v][1]=edge[i].w+mx[u][0];id[v][1]=u;}}if(mx[v][0]<mx[v][1]){swap(mx[v][0],mx[v][1]);swap(id[v][0],id[v][1]);}dfs2(v,u);} }int n,u,w;int main(){//freopen("in.txt","r",stdin);while(~scanf("%d",&n)){init();for(int i=2;i<=n;i++){scanf("%d%d",&u,&w);addedge(i,u,w);}dfs1(1,-1);dfs2(1,-1);for(int i=1;i<=n;i++) printf("%d\n",mx[i][0]);}return 0; } View Code

5.POJ 2152

題意:樹中每個(gè)結(jié)點(diǎn)有兩個(gè)值:w[i]表示在i建設(shè)防火設(shè)施的價(jià)格,d[i]表示與i最近的防火設(shè)施的距離上限,求滿足所有d[i]的最小花費(fèi)

算是一道比較難的樹形dp,狀態(tài)和普通的樹形DP略有不同

樹形dp很多時(shí)候是把一個(gè)結(jié)點(diǎn)及其子樹看成一個(gè)整體,然后考慮這個(gè)結(jié)點(diǎn)的狀態(tài)進(jìn)行轉(zhuǎn)移

考慮到數(shù)據(jù)范圍N<=1000,可以定義狀態(tài)dp[u][i]表示u依靠i時(shí),保證子樹內(nèi)安全的最小花費(fèi)

為了轉(zhuǎn)移方便,再定義all[u]表示保證u的安全的最小花費(fèi)

其實(shí)可以理解為all[u]是在dp[u][i]中取了個(gè)最優(yōu)值

要確定一個(gè)點(diǎn)是否能被u依靠就需要知道u與該點(diǎn)的距離

所以先n^2處理樹中任意兩點(diǎn)的距離

考慮葉子結(jié)點(diǎn):dp[u][i]=w[i]

考慮一個(gè)非葉子結(jié)點(diǎn)u,先枚舉它依靠的結(jié)點(diǎn)i

再考慮u的兒子v,v可以選擇依靠或者不依靠i,則dp[u][i]+=min(dp[v][i]-c[i],all[v])

對(duì)于u的每一個(gè)i更新u的最優(yōu)解all[u]

對(duì)于u的孫子k是不需要考慮的,因?yàn)閗依靠i的情況在解決v的時(shí)候已經(jīng)考慮到了,所以不會(huì)有重復(fù)計(jì)算的情況

#include"cstdio" #include"queue" #include"cmath" #include"stack" #include"iostream" #include"algorithm" #include"cstring" #include"queue" #include"map" #include"set" #include"vector" #include"bitset" #define LL long long #define ull unsigned long long #define mems(a,b) memset(a,b,sizeof(a)) #define mdzz int mid=(L+R)>>1 #define ls pos<<1 #define rs pos<<1|1 #define lson L,mid,pos<<1 #define rson mid+1,R,pos<<1|1 #pragma comment(linker, "/STACK:1024000000,1024000000") using namespace std;const int N = 1e3+5; const int M = 2e3+5; const int MOD = 998244353; const int INF = 0x3f3f3f3f;int tot; int first[N]; int dp[N][N],all[N]; int n,u,v,x; int cost[N],d[N],dis[N][N];struct node{int e,next,w;node(){}node(int a,int b,int c):e(a),next(b),w(c){} }edge[M];void init(){tot=0;mems(first,-1);mems(all,INF);mems(dp,INF); }void addedge(int u,int v,int w){edge[tot]=node(v,first[u],w);first[u]=tot++;edge[tot]=node(u,first[v],w);first[v]=tot++; }void dfs1(int rt,int u,int fa){for(int i=first[u];i!=-1;i=edge[i].next){int v=edge[i].e;if(v==fa) continue;dis[rt][v]=dis[rt][u]+edge[i].w;dfs1(rt,v,u);} }void dfs2(int u,int fa){for(int i=first[u];i!=-1;i=edge[i].next){int v=edge[i].e;if(v==fa) continue;dfs2(v,u);}for(int k=1;k<=n;k++) if(dis[u][k]<=d[u]){dp[u][k]=cost[k];for(int i=first[u];i!=-1;i=edge[i].next){int v=edge[i].e;if(v==fa) continue;dp[u][k]+=min(dp[v][k]-cost[k],all[v]);}all[u]=min(all[u],dp[u][k]);} }int T; int main(){//freopen("in.txt","r",stdin);for(int i=0;i<N;i++) dis[i][i]=0;scanf("%d",&T);while(T--){init();scanf("%d",&n);for(int i=1;i<=n;i++) scanf("%d",&cost[i]);for(int i=1;i<=n;i++) scanf("%d",&d[i]);for(int i=1;i<n;i++){scanf("%d%d%d",&u,&v,&x);addedge(u,v,x);}for(int i=1;i<=n;i++) dfs1(i,i,-1);dfs2(1,-1);printf("%d\n",all[1]);}return 0; } View Code

6.POJ 3162

題意:對(duì)于樹中每一個(gè)結(jié)點(diǎn)i找到另一個(gè)結(jié)點(diǎn)使得兩者距離dp[i]最遠(yuǎn),最后輸出一段最長區(qū)間的長度,區(qū)間maxv-minv<=M

只是在樹形dp上加了點(diǎn)東西而已,用線段樹+two pointer維護(hù)就好了

#include"cstdio" #include"queue" #include"cmath" #include"stack" #include"iostream" #include"algorithm" #include"cstring" #include"queue" #include"map" #include"set" #include"vector" #include"bitset" #define LL long long #define ull unsigned long long #define mems(a,b) memset(a,b,sizeof(a)) #define mdzz int mid=(L+R)>>1 #define ls pos<<1 #define rs pos<<1|1 #define lson L,mid,pos<<1 #define rson mid+1,R,pos<<1|1 #pragma comment(linker, "/STACK:1024000000,1024000000") using namespace std;const int N = 1e6+5; const int M = 2e6+5; const int MOD = 998244353; const int INF = 0x3f3f3f3f;int tot; int first[N]; int dp[N][2],id[N][2];struct node{int e,next,w;node(){}node(int a,int b,int c):e(a),next(b),w(c){} }edge[M];void init(){tot=0;mems(first,-1); }void addedge(int u,int v,int w){edge[tot]=node(v,first[u],w);first[u]=tot++;edge[tot]=node(u,first[v],w);first[v]=tot++; }void update(int u){if(dp[u][0]<dp[u][1]){swap(dp[u][0],dp[u][1]);swap(id[u][0],id[u][1]);} }void dfs1(int u,int fa){dp[u][1]=dp[u][0]=0;for(int i=first[u];i!=-1;i=edge[i].next){int v=edge[i].e;if(v==fa) continue;dfs1(v,u);if(edge[i].w+dp[v][0]>dp[u][1]){dp[u][1]=edge[i].w+dp[v][0];id[u][1]=v;}update(u);} }void dfs2(int u,int fa){for(int i=first[u];i!=-1;i=edge[i].next){int v=edge[i].e;if(v==fa) continue;if(id[u][0]==v){if(dp[u][1]+edge[i].w>dp[v][1]){dp[v][1]=dp[u][1]+edge[i].w;id[v][1]=u;}}else{if(dp[u][0]+edge[i].w>dp[v][1]){dp[v][1]=dp[u][0]+edge[i].w;id[v][1]=u;}}update(v);dfs2(v,u);} }int minv[N<<2],maxv[N<<2];void build(int L,int R,int pos){if(L==R){minv[pos]=maxv[pos]=dp[L][0];return;}mdzz;build(lson);build(rson);minv[pos]=min(minv[ls],minv[rs]);maxv[pos]=max(maxv[ls],maxv[rs]); }int query_min(int l,int r,int L,int R,int pos){if(l<=L&&R<=r) return minv[pos];mdzz;int ans=INF;if(l<=mid) ans=min(ans,query_min(l,r,lson));if(r>mid) ans=min(ans,query_min(l,r,rson));return ans; }int query_max(int l,int r,int L,int R,int pos){if(l<=L&&R<=r) return maxv[pos];mdzz;int ans=-INF;if(l<=mid) ans=max(ans,query_max(l,r,lson));if(r>mid) ans=max(ans,query_max(l,r,rson));return ans; }int n,m,u,v; int main(){//freopen("in.txt","r",stdin);while(~scanf("%d%d",&n,&m)){init();for(int i=2;i<=n;i++){scanf("%d%d",&u,&v);addedge(i,u,v);}dfs1(1,-1);dfs2(1,-1);int ans=0;build(1,n,1);int l=1,r=1;while(1){if(l>r||l>n||r>n) break;int mxv=query_max(l,r,1,n,1);int miv=query_min(l,r,1,n,1);if(mxv-miv<=m){ans=max(ans,r-l+1);r++;}else l++;}printf("%d\n",ans);}return 0; } View Code

7.codeforces 219D

題意:樹邊有方向,選擇一個(gè)點(diǎn),翻轉(zhuǎn)最少路徑,使得其能到達(dá)其余所有的點(diǎn),輸出所有可能的答案

可以將翻轉(zhuǎn)理解為一種花費(fèi),那不翻轉(zhuǎn)就是花費(fèi)0,翻轉(zhuǎn)則為1

可以定義dp[u]表示u到所有點(diǎn)的距離和,那dp[u]最小的就是答案

依舊先考慮u的子樹內(nèi)的答案

考慮一個(gè)葉子:dp[u]=0;

考慮一個(gè)非葉子u以及其的一個(gè)兒子v:很容易想到dp[u]+=dp[v]+w[u,v]

一次dfs下來后rt的答案已知,接下來通過rt來推其余結(jié)點(diǎn)對(duì)于整棵樹的答案

考慮結(jié)點(diǎn)u及其一個(gè)兒子v,v到v子樹內(nèi)的答案已知,v到u除v子樹的結(jié)點(diǎn)的答案是dp[u]-dp[v]-w[u,v]

所以dp[v]+=dp[u]-dp[v]-w[u,v]+w[v,u]

#include"cstdio" #include"queue" #include"cmath" #include"stack" #include"iostream" #include"algorithm" #include"cstring" #include"queue" #include"map" #include"set" #include"vector" #include"bitset" #define LL long long #define ull unsigned long long #define mems(a,b) memset(a,b,sizeof(a)) #define mdzz int mid=(L+R)>>1 #pragma comment(linker, "/STACK:1024000000,1024000000") using namespace std;const int N = 2e5+5; const int M = 4e5+5; const int MOD = 998244353; const int INF = 0x3f3f3f3f;int tot; int first[N]; int dp[N],sz[N];struct node{int e,next,w;node(){}node(int a,int b,int c):e(a),next(b),w(c){} }edge[M];void init(){tot=0;mems(first,-1); }void addedge(int u,int v){edge[tot]=node(v,first[u],0);first[u]=tot++;edge[tot]=node(u,first[v],1);first[v]=tot++; }void dfs1(int u,int fa){dp[u]=0;sz[u]=1;for(int i=first[u];i!=-1;i=edge[i].next){int v=edge[i].e;if(v==fa) continue;dfs1(v,u);sz[u]+=sz[v];dp[u]+=dp[v]+edge[i].w;} }void dfs2(int u,int fa){for(int i=first[u];i!=-1;i=edge[i].next){int v=edge[i].e;if(v==fa) continue;dp[v]+=(dp[u]-dp[v]-edge[i].w)+(edge[i].w^1);dfs2(v,u);} }int n,u,v; int main(){init();scanf("%d",&n);for(int i=1;i<n;i++){scanf("%d%d",&u,&v);addedge(u,v);}dfs1(1,-1);dfs2(1,-1);int ans=INF;for(int i=1;i<=n;i++) ans=min(ans,dp[i]);//for(int i=1;i<=n;i++) cout<<i<<' '<<dp[i]<<endl;printf("%d\n",ans);for(int i=1;i<=n;i++) if(ans==dp[i]) printf("%d ",i);return 0; } View Code

8.POJ 1155

題意:樹中每個(gè)葉子有點(diǎn)權(quán)表示收入,邊權(quán)表示花費(fèi)。選擇某些葉子后,不必要的邊可刪掉,最多選擇幾個(gè)點(diǎn)使得花費(fèi)>=收入

狀態(tài)很多時(shí)候是根據(jù)要求的東西來定義的

這里定義dp[u][i]為子樹u取i個(gè)葉子的最優(yōu)解

由于不選葉子的話是不需要任何花費(fèi)的,所以容易想到dp[u][0]=0

考慮一個(gè)葉子,其第二維只有0/1兩種取值,1的話明顯是dp[u][1]=w[u]

考慮一個(gè)非葉子,第二維1~sz[u]都是無法確定的狀態(tài),而且考慮到結(jié)果可能是負(fù)值,而且我們需要的是一個(gè)最大值,所以初始化為-INF

對(duì)于一個(gè)結(jié)點(diǎn)u的一個(gè)兒子v,枚舉在這個(gè)兒子中取的葉子數(shù)k,維護(hù)個(gè)最優(yōu)解就好了

#include"cstdio" #include"queue" #include"cmath" #include"stack" #include"iostream" #include"algorithm" #include"cstring" #include"queue" #include"map" #include"set" #include"vector" #include"bitset" #define LL long long #define ull unsigned long long #define mems(a,b) memset(a,b,sizeof(a)) #define mdzz int mid=(L+R)>>1 #define ls pos<<1 #define rs pos<<1|1 #define lson L,mid,pos<<1 #define rson mid+1,R,pos<<1|1 #pragma comment(linker, "/STACK:1024000000,1024000000") using namespace std;const int N = 3e3+5; const int M = 2e3+5; const int MOD = 998244353; const int INF = 0x3f3f3f3f;struct node{int e,next,w;node(){}node(int a,int b,int c):e(a),next(b),w(c){} }edge[N<<1];int tot; int first[N],w[N],dp[N][N],sz[N];void init(){tot=0;mems(first,-1);mems(w,0); }void addedge(int u,int v,int w){edge[tot]=node(v,first[u],w);first[u]=tot++;edge[tot]=node(u,first[v],w);first[v]=tot++; }void dfs1(int u,int fa){int f=0;sz[u]=0;dp[u][0]=0;for(int i=first[u];i!=-1;i=edge[i].next){int v=edge[i].e;if(v==fa) continue;f=1;dfs1(v,u);sz[u]+=sz[v];}if(!f){sz[u]=1;dp[u][1]=w[u];}else{for(int i=1;i<=sz[u];i++)dp[u][i]=-INF;} }void dfs2(int u,int fa){for(int i=first[u];i!=-1;i=edge[i].next){int v=edge[i].e;if(v==fa) continue;dfs2(v,u);for(int j=sz[u];j>=1;j--)for(int k=1;k<=sz[v];k++) if(j>=k)dp[u][j]=max(dp[u][j],dp[u][j-k]+dp[v][k]-edge[i].w);} }int n,m,u,v,k; int main(){//freopen("in.txt","r",stdin);while(~scanf("%d%d",&n,&m)){init();for(int i=1;i<=n-m;i++){scanf("%d",&k);for(int j=0;j<k;j++){scanf("%d%d",&u,&v);addedge(i,u,v);}}for(int i=n-m+1;i<=n;i++) scanf("%d",&w[i]);dfs1(1,-1);dfs2(1,-1);for(int i=m;i>=0;i--) if(dp[1][i]>=0){printf("%d\n",i);break;}}return 0; } View Code

9.HDU 1011

題意:樹中每一個(gè)結(jié)點(diǎn)有一個(gè)花費(fèi)一個(gè)收益,問K元能取得的最大收益是多少

明顯的樹形背包,一個(gè)結(jié)點(diǎn)可以看成一個(gè)物品

XJB搞搞就行了

有個(gè)坑是a/20向上取整不能寫成(a-1)/20+1,a可能是0

#include"cstdio" #include"queue" #include"cmath" #include"stack" #include"iostream" #include"algorithm" #include"cstring" #include"queue" #include"map" #include"set" #include"vector" #include"bitset" #define LL long long #define ull unsigned long long #define mems(a,b) memset(a,b,sizeof(a)) #define mdzz int mid=(L+R)>>1 #define ls pos<<1 #define rs pos<<1|1 #define lson L,mid,pos<<1 #define rson mid+1,R,pos<<1|1 #pragma comment(linker, "/STACK:1024000000,1024000000") using namespace std;const int N = 105; const int M = 2e3+5; const int MOD = 998244353; const int INF = 0x3f3f3f3f;struct node{int e,next;node(){}node(int a,int b):e(a),next(b){} }edge[N<<1];int tot,n,m; int first[N],c[N],p[N],dp[N][N];void init(){tot=0;mems(first,-1);mems(dp,0); }void addedge(int u,int v){edge[tot]=node(v,first[u]);first[u]=tot++;edge[tot]=node(u,first[v]);first[v]=tot++; }void dfs1(int u,int fa){int x=(c[u]+19)/20;for(int i=x;i<=m;i++) dp[u][i]=p[u];for(int i=first[u];i!=-1;i=edge[i].next){int v=edge[i].e;if(v==fa) continue;dfs1(v,u);for(int j=m;j>=x;j--)for(int k=1;k<=j-x;k++)dp[u][j]=max(dp[u][j],dp[u][j-k]+dp[v][k]);} }int main(){//freopen("in.txt","r",stdin);while(~scanf("%d%d",&n,&m)){if(n==-1&&m==-1) break;init();for(int i=1;i<=n;i++) scanf("%d%d",&c[i],&p[i]);int u,v;for(int i=1;i<n;i++){scanf("%d%d",&u,&v);addedge(u,v);}if(!m){puts("0");continue;}dfs1(1,-1);printf("%d\n",dp[1][m]);}return 0; } View Code

10.POJ 1947

題意:問最少需要破壞多少條邊能產(chǎn)生一個(gè)大小為K的塊

dp[u][i]表示u的子樹中產(chǎn)生一個(gè)i大小的塊需要破壞的最少邊數(shù)

num[u]表示u的兒子數(shù)

這題考慮的方向不同平常

考慮塊的大小1~sz[u] (0的大小是不合法的狀態(tài))

若要在u的子樹中產(chǎn)生一個(gè)1大小的塊,初始情況應(yīng)該是u和所有兒子的連邊斷開,所以dp[u][1]=num[u]

其實(shí)這樣處理相當(dāng)于對(duì)于每一個(gè)狀態(tài)來說u都是默認(rèn)取了的

考慮一個(gè)結(jié)點(diǎn)u及其一個(gè)兒子v,對(duì)于狀態(tài)dp[u][i] 枚舉在v中取的結(jié)點(diǎn)數(shù)k

最后要枚舉一個(gè)塊的根,因?yàn)槲覀冎疤幚頎顟B(tài)的時(shí)候是默認(rèn)根取,所以最優(yōu)解還可能在子樹中

如果加一維狀態(tài)[0/1]表示u是否取的話應(yīng)該可以避免這個(gè)問題,不過也沒有去嘗試了

#include"cstdio" #include"queue" #include"cmath" #include"stack" #include"iostream" #include"algorithm" #include"cstring" #include"queue" #include"map" #include"set" #include"vector" #include"bitset" #define LL long long #define ull unsigned long long #define mems(a,b) memset(a,b,sizeof(a)) #define mdzz int mid=(L+R)>>1 #define ls pos<<1 #define rs pos<<1|1 #define lson L,mid,pos<<1 #define rson mid+1,R,pos<<1|1 #pragma comment(linker, "/STACK:1024000000,1024000000") using namespace std;const int N = 155; const int M = 2e3+5; const int MOD = 998244353; const int INF = 0x3f3f3f3f;struct node{int e,next;node(){}node(int a,int b):e(a),next(b){} }edge[N<<1];int tot,n,m; int first[N],dp[N][N],sz[N],num[N];void init(){tot=0;mems(first,-1);mems(dp,INF); }void addedge(int u,int v){edge[tot]=node(v,first[u]);first[u]=tot++;edge[tot]=node(u,first[v]);first[v]=tot++; }void dfs1(int u,int fa){sz[u]=1;num[u]=0;for(int i=first[u];i!=-1;i=edge[i].next){int v=edge[i].e;if(v==fa) continue;dfs1(v,u);num[u]++;sz[u]+=sz[v];} }void dfs2(int u,int fa){dp[u][1]=num[u];for(int i=first[u];i!=-1;i=edge[i].next){int v=edge[i].e;if(v==fa) continue;dfs2(v,u);for(int j=m;j>=1;j--)for(int k=1;k<=sz[v];k++)if(j-k>=1) dp[u][j]=min(dp[u][j],dp[u][j-k]+dp[v][k]-1);} }int main(){//freopen("in.txt","r",stdin);while(~scanf("%d%d",&n,&m)){init();int u,v;for(int i=1;i<n;i++){scanf("%d%d",&u,&v);addedge(u,v);}dfs1(1,-1);dfs2(1,-1);/*for(int i=1;i<=n;i++){cout<<i<<":"<<endl;for(int j=1;j<=sz[i];j++) cout<<dp[i][j]<<' ';cout<<endl;}*/int ans=dp[1][m];for(int i=2;i<=n;i++) ans=min(ans,dp[i][m]+1);printf("%d\n",ans);}return 0; } View Code

11.HDU 1561

題意:每個(gè)結(jié)點(diǎn)有一個(gè)權(quán)值,問選擇K個(gè)結(jié)點(diǎn)(必須按路徑選擇)獲得的最大權(quán)值

典型的樹形背包

由于不是任意選,我們只需要在狀態(tài)轉(zhuǎn)移的時(shí)候變通一下就好了

對(duì)于u來說,我要選擇其子孫的話前提是u選擇

所以對(duì)第二維i==1的時(shí)候單獨(dú)處理,而且之后不再更新這個(gè)值就能保證u是默認(rèn)被選擇的

#include"cstdio" #include"queue" #include"cmath" #include"stack" #include"iostream" #include"algorithm" #include"cstring" #include"queue" #include"map" #include"set" #include"vector" #include"bitset" #define LL long long #define ull unsigned long long #define mems(a,b) memset(a,b,sizeof(a)) #define mdzz int mid=(L+R)>>1 #define ls pos<<1 #define rs pos<<1|1 #define lson L,mid,pos<<1 #define rson mid+1,R,pos<<1|1 #pragma comment(linker, "/STACK:1024000000,1024000000") using namespace std;const int N = 205; const int M = 2e3+5; const int MOD = 998244353; const int INF = 0x3f3f3f3f;struct node{int e,next;node(){}node(int a,int b):e(a),next(b){} }edge[N];int tot,n,m; int first[N],dp[N][N],w[N];void init(){tot=0;mems(first,-1);mems(dp,0); }void addedge(int u,int v){edge[tot]=node(v,first[u]);first[u]=tot++;//edge[tot]=node(u,first[v]);// first[v]=tot++; }void dfs(int u){dp[u][1]=w[u];for(int i=first[u];i!=-1;i=edge[i].next){int v=edge[i].e;dfs(v);for(int j=m;j>=2;j--)for(int k=0;k<=m;k++)if(j-1>=k) dp[u][j]=max(dp[u][j],dp[u][j-k]+dp[v][k]);} }int main(){//freopen("in.txt","r",stdin);w[0]=0;while(scanf("%d%d",&n,&m)&&(n||m)){init();m++;int rt=0,u;for(int i=1;i<=n;i++){scanf("%d%d",&u,&w[i]);addedge(u,i);}dfs(rt);printf("%d\n",dp[rt][m]);}return 0; } View Code

12.HDU 4003

題意:樹中每條邊有花費(fèi),有k個(gè)機(jī)器人,問遍歷所有的點(diǎn)的最少花費(fèi)(可以回頭,每次只能從s出發(fā)

這一題的狀態(tài)定義很有意思

dp[u][i]表示遍歷完u的子樹后有i個(gè)機(jī)器人沒有回到u結(jié)點(diǎn)的最優(yōu)解

對(duì)于每一棵子樹都是需要遍歷完的,所以必須選擇一個(gè)方案

為了保證至少選擇一個(gè)方案,所以在考慮當(dāng)前兒子v的時(shí)候先將答案加上一個(gè)狀態(tài),這里是加上沒有機(jī)器人留在v子樹的方案

然后再對(duì)v做一個(gè)背包,若有更優(yōu)解則初始放置的選擇將被替換掉

其實(shí)相當(dāng)于對(duì)于子樹v有k件物品來選擇,必須選擇一件

#include"cstdio" #include"queue" #include"cmath" #include"stack" #include"iostream" #include"algorithm" #include"cstring" #include"queue" #include"map" #include"set" #include"vector" #include"bitset" #define LL long long #define ull unsigned long long #define mems(a,b) memset(a,b,sizeof(a)) #define mdzz int mid=(L+R)>>1 #pragma comment(linker, "/STACK:1024000000,1024000000") using namespace std;const int N = 1e4+5; const int M = N<<1; const LL MOD = 998244353; const int INF = 0x3f3f3f3f;struct node{int e,next,w;node(){}node(int a,int b,int c):e(a),next(b),w(c){} }edge[N<<1];int tot; int first[N],dp[N][12];void init(){tot=0;mems(first,-1);mems(dp,0); }void addedge(int u,int v,int w){edge[tot]=node(v,first[u],w);first[u]=tot++;edge[tot]=node(u,first[v],w);first[v]=tot++; }int n,s,m;void dfs(int u,int fa){for(int i=first[u];i!=-1;i=edge[i].next){int v=edge[i].e;if(v==fa) continue;dfs(v,u);for(int j=m;j>=0;j--){dp[u][j]+=dp[v][0]+edge[i].w*2;for(int k=1;k<=j;k++)dp[u][j]=min(dp[u][j],dp[v][k]+dp[u][j-k]+edge[i].w*k);}} }int main(){//freopen("in.txt","r",stdin);while(~scanf("%d%d%d",&n,&s,&m)){init();int u,v,w;for(int i=1;i<n;i++){scanf("%d%d%d",&u,&v,&w);addedge(u,v,w);}dfs(s,-1);printf("%d\n",dp[s][m]);}return 0; } View Code

13.HDU 4276

題意:每個(gè)點(diǎn)有點(diǎn)權(quán),邊有花費(fèi),問T時(shí)間能否從1到達(dá)n,若能,能獲取的最大權(quán)值是多少

首先想到樹中兩點(diǎn)的路徑是唯一的,既然要從1到達(dá)n,先考慮最短路徑能否到達(dá)

之后剩余的時(shí)間作為背包容量,因?yàn)槠溆嗟狞c(diǎn)都是非必須的,所以去了必須還要回來,故每條非必要的邊花費(fèi)都需要*2

?所以做法就是先把總時(shí)間減去1到n的路徑距離,并把路徑上的花費(fèi)置零

然后對(duì)于每一個(gè)結(jié)點(diǎn)做背包,對(duì)于u的兒子v枚舉一個(gè)花費(fèi)k,注意邊的花費(fèi)要double

#include"cstdio" #include"queue" #include"cmath" #include"stack" #include"iostream" #include"algorithm" #include"cstring" #include"queue" #include"map" #include"set" #include"vector" #include"bitset" #define LL long long #define ull unsigned long long #define mems(a,b) memset(a,b,sizeof(a)) #define mdzz int mid=(L+R)>>1 #pragma comment(linker, "/STACK:1024000000,1024000000") using namespace std;const int N = 105; const int M = N<<1; const LL MOD = 998244353; const int INF = 0x3f3f3f3f;struct node{int e,next,w;node(){}node(int a,int b,int c):e(a),next(b),w(c){} }edge[N<<1];int tot; int first[N],dp[N][N*5],pre[N],id[N],w[N],inq[N],dis[N];void init(){tot=0;mems(first,-1);mems(dp,0);mems(inq,0);mems(dis,INF); }void addedge(int u,int v,int W){edge[tot]=node(v,first[u],W);first[u]=tot++;edge[tot]=node(u,first[v],W);first[v]=tot++; }int n,m,cnt; queue<int>q;void bfs(int s){while(!q.empty()) q.pop();pre[s]=1;dis[s]=0;inq[s]=1;q.push(s);while(!q.empty()){int u=q.front();q.pop();inq[u]=0;if(u==n) break;for(int i=first[u];i!=-1;i=edge[i].next){int v=edge[i].e;if(!inq[v]&&dis[u]+edge[i].w<dis[v]){dis[v]=dis[u]+edge[i].w;q.push(v);inq[u]=1;pre[v]=u;id[v]=i;}}}cnt=0;int u=n;while(u!=1){cnt+=edge[id[u]].w;edge[id[u]].w=edge[id[u]^1].w=0;u=pre[u];} }void dfs2(int u,int fa){for(int i=0;i<=m;i++) dp[u][i]=w[u];for(int i=first[u];i!=-1;i=edge[i].next){int v=edge[i].e;if(v==fa) continue;dfs2(v,u);for(int j=m;j>=0;j--)for(int k=0;k<=j;k++) if(j-edge[i].w*2-k>=0)dp[u][j]=max(dp[u][j],dp[v][k]+dp[u][j-edge[i].w*2-k]);} }int u,v,W; int main(){//freopen("in.txt","r",stdin);while(~scanf("%d%d",&n,&m)){init();for(int i=1;i<n;i++){scanf("%d%d%d",&u,&v,&W);addedge(u,v,W);}for(int i=1;i<=n;i++) scanf("%d",&w[i]);bfs(1);if(cnt>m){printf("Human beings die in pursuit of wealth, and birds die in pursuit of food!\n");continue;}m-=cnt;dfs2(1,-1);/*for(int i=1;i<=n;i++){cout<<i<<':'<<endl;for(int j=0;j<=m;j++) cout<<dp[i][j]<<' ';cout<<endl;}*/printf("%d\n",dp[1][m]);}return 0; } View Code

14.HDU 3586

題意:給一個(gè)限制m,切斷的路徑權(quán)值和不超過m,單個(gè)邊權(quán)值也不超過k,求最小的k使得所有葉子和根不相連

二分一個(gè)k

對(duì)于一個(gè)確定的k,dp[u]表示u的葉子全部和u分離需要的最小花費(fèi)

考慮葉子節(jié)點(diǎn):dp[u]=INF(不合法狀態(tài)

考慮非葉子結(jié)點(diǎn):一開始是沒有和兒子相連,所以dp[u]=0

考慮u的一個(gè)兒子v,若(u,v)這條邊是<=lim,則可以選擇在消除這條邊或者是在v的子樹中消除,兩者取一個(gè)最優(yōu)解

最后判斷dp[1]是否小于給定的m

#include"cstdio" #include"queue" #include"cmath" #include"stack" #include"iostream" #include"algorithm" #include"cstring" #include"queue" #include"map" #include"set" #include"vector" #include"bitset" #define LL long long #define ull unsigned long long #define mems(a,b) memset(a,b,sizeof(a)) #define mdzz int mid=(L+R)>>1 #pragma comment(linker, "/STACK:1024000000,1024000000") using namespace std;const int N = 1005; const int M = N<<1; const LL MOD = 998244353; const int INF = 0x3f3f3f;struct node{int e,next,w;node(){}node(int a,int b,int c):e(a),next(b),w(c){} }edge[N<<1];int tot,n,m; int first[N],dp[N];void init(){tot=0;mems(first,-1); }void addedge(int u,int v,int w){edge[tot]=node(v,first[u],w);first[u]=tot++;edge[tot]=node(u,first[v],w);first[v]=tot++; }void dfs(int u,int fa,int lim){dp[u]=0;int f=0;for(int i=first[u];i!=-1;i=edge[i].next){int v=edge[i].e;if(v==fa) continue;dfs(v,u,lim);f=1;int tmp;if(edge[i].w<=lim) tmp=edge[i].w;else tmp=INF;dp[u]+=min(tmp,dp[v]);}if(!f) dp[u]=INF; }bool check(int mid){mems(dp,INF);dfs(1,-1,mid);return dp[1]<=m; }int u,v,w; int main(){//freopen("in.txt","r",stdin);while(scanf("%d%d",&n,&m)&&(n||m)){init();for(int i=1;i<n;i++){scanf("%d%d%d",&u,&v,&w);addedge(u,v,w);}int low=1,high=INF,mid,ans=-1;while(low<=high){mid=(low+high)>>1;if(check(mid)){ans=mid;high=mid-1;}else low=mid+1;}printf("%d\n",ans);}return 0; } View Code

15. POJ 3107

題意:輸出樹中的結(jié)點(diǎn)k,刪去k后產(chǎn)生的最大的聯(lián)通塊最小

直接兩次dp就好了,第一次處理子樹第二次考慮父親除去當(dāng)前結(jié)點(diǎn)產(chǎn)生的最大塊,維護(hù)個(gè)最大值

#include"cstdio" #include"queue" #include"cmath" #include"stack" #include"iostream" #include"algorithm" #include"cstring" #include"queue" #include"map" #include"set" #include"vector" #include"bitset" #define LL long long #define ull unsigned long long #define mems(a,b) memset(a,b,sizeof(a)) #define mdzz int mid=(L+R)>>1 #pragma comment(linker, "/STACK:1024000000,1024000000") using namespace std;const int N = 50005; const int M = N<<1; const LL MOD = 998244353; const int INF = 0x3f3f3f;struct node{int e,next,w;node(){}node(int a,int b):e(a),next(b){} }edge[N<<1];int tot,n,m; int first[N],dp[N],sz[N]; vector<int> ans; void init(){tot=0;ans.clear();mems(first,-1); }void addedge(int u,int v){edge[tot]=node(v,first[u]);first[u]=tot++;edge[tot]=node(u,first[v]);first[v]=tot++; }void dfs1(int u,int fa){sz[u]=1;dp[u]=0;for(int i=first[u];i!=-1;i=edge[i].next){int v=edge[i].e;if(v==fa) continue;dfs1(v,u);sz[u]+=sz[v];dp[u]=max(dp[u],sz[v]);} }void dfs2(int u,int fa){for(int i=first[u];i!=-1;i=edge[i].next){int v=edge[i].e;if(v==fa) continue;dp[v]=max(dp[v],n-sz[v]);dfs2(v,u);} }int main(){//freopen("in.txt","r",stdin);while(~scanf("%d",&n)){init();int u,v;for(int i=1;i<n;i++){scanf("%d%d",&u,&v);addedge(u,v);}dfs1(1,-1);dfs2(1,-1);int cnt=INF;for(int i=1;i<=n;i++) cnt=min(cnt,dp[i]);//for(int i=1;i<=n;i++) cout<<i<<' '<<dp[i]<<endl;for(int i=1;i<=n;i++) if(dp[i]==cnt) ans.push_back(i);for(int i=0;i<ans.size();i++){if(i) printf(" ");printf("%d",ans[i]);}puts("");}return 0; } View Code

16.POJ 3140

題意:選擇一條樹邊斷開,使得分成的兩部分的總點(diǎn)權(quán)差最小,輸出最小值

就直接預(yù)處理每一個(gè)點(diǎn)及其子樹的總點(diǎn)權(quán)

枚舉一個(gè)點(diǎn)和其父親斷開,取個(gè)最優(yōu)值就好了

#include"cstdio" #include"queue" #include"cmath" #include"stack" #include"iostream" #include"algorithm" #include"cstring" #include"queue" #include"map" #include"set" #include"vector" #include"bitset" #define LL long long #define ull unsigned long long #define mems(a,b) memset(a,b,sizeof(a)) #define mdzz int mid=(L+R)>>1 #pragma comment(linker, "/STACK:1024000000,1024000000") using namespace std;const int N = 1e5+5; const int M = N<<1; const LL MOD = 998244353; const LL INF = 1e18;struct node{int e,next;node(){}node(int a,int b):e(a),next(b){} }edge[N<<1];int tot,n,m; int first[N]; LL sz[N],num[N],cnt;void init(){tot=0;cnt=0;mems(first,-1); }void addedge(int u,int v){edge[tot]=node(v,first[u]);first[u]=tot++;edge[tot]=node(u,first[v]);first[v]=tot++; }void dfs(int u,int fa){sz[u]=num[u];for(int i=first[u];i!=-1;i=edge[i].next){int v=edge[i].e;if(v==fa) continue;dfs(v,u);sz[u]+=sz[v];} } int u,v,cas=1; int main(){//freopen("in.txt","r",stdin);while(scanf("%d%d",&n,&m)&&(n||m)){init();for(int i=1;i<=n;i++) scanf("%lld",&num[i]),cnt+=num[i];for(int i=1;i<n;i++){scanf("%d%d",&u,&v);addedge(u,v);}dfs(1,-1);LL ans=INF;for(int i=2;i<=n;i++){LL tmp=cnt-sz[i]*2;if(tmp<0) tmp*=-1;ans=min(ans,tmp);}printf("Case %d: %lld\n",cas++,ans);}return 0; } View Code

17. POJ 2486

題意:從樹根1走K步能獲得的最大點(diǎn)權(quán),可以走回頭路

dp[u][i][0/1]表示從u出發(fā)走i步,最終回到u/不回到u的最優(yōu)值

考慮一個(gè)葉子結(jié)點(diǎn):dp[u][0][0]=w[u];

考慮一個(gè)非葉子結(jié)點(diǎn)u及其一個(gè)兒子v,枚舉一個(gè)k表示對(duì)于這個(gè)兒子v走的步數(shù)

有3種結(jié)果:留在v子樹,回到u,留在u其它子樹

畫圖就能看出三種情況的轉(zhuǎn)移:

留在v子樹:狀態(tài)分裂為dp[u][j-k-1][0],dp[v][k][1] ?花費(fèi)為1步

回到u:狀態(tài)分裂為dp[u][j-k-2][0],dp[v][k][0] 花費(fèi)為2步

留在其他子樹:狀態(tài)分裂為dp[u][j-k-2][1],dp[v][k][0] 花費(fèi)為2步

#include"cstdio" #include"queue" #include"cmath" #include"stack" #include"iostream" #include"algorithm" #include"cstring" #include"queue" #include"map" #include"set" #include"vector" #include"bitset" #define LL long long #define ull unsigned long long #define mems(a,b) memset(a,b,sizeof(a)) #define mdzz int mid=(L+R)>>1 #pragma comment(linker, "/STACK:1024000000,1024000000") using namespace std;const int N = 105; const int M = N<<1; const LL MOD = 998244353; const int INF = 0x3f3f3f3f;struct node{int e,next,w;node(){}node(int a,int b):e(a),next(b){} }edge[N<<1];int tot; int first[N],dp[N][N<<1][2],w[N];void init(){tot=0;mems(first,-1);mems(dp,0); }void addedge(int u,int v){edge[tot]=node(v,first[u]);first[u]=tot++;edge[tot]=node(u,first[v]);first[v]=tot++; }int n,m;void dfs(int u,int fa){for(int i=0;i<=m;i++) dp[u][i][0]=dp[u][i][1]=w[u];for(int i=first[u];i!=-1;i=edge[i].next){int v=edge[i].e;if(v==fa) continue;dfs(v,u);for(int j=m;j>=1;j--)for(int k=0;k<=j;k++){if(j>=k+2) dp[u][j][0]=max(dp[u][j][0],dp[v][j-k-2][0]+dp[u][k][0]);if(j>=k+1) dp[u][j][1]=max(dp[u][j][1],dp[v][j-k-1][1]+dp[u][k][0]);if(j>=k+2) dp[u][j][1]=max(dp[u][j][1],dp[v][j-k-2][0]+dp[u][k][1]);}} }int main(){//freopen("in.txt","r",stdin);while(~scanf("%d%d",&n,&m)){init();for(int i=1;i<=n;i++) scanf("%d",&w[i]);int u,v;for(int i=1;i<n;i++){scanf("%d%d",&u,&v);addedge(u,v);}dfs(1,-1);printf("%d\n",max(dp[1][m][0],dp[1][m][1]));}return 0; } View Code

18. HDU 4044

題意:每個(gè)點(diǎn)有ki種選擇,每種選擇對(duì)應(yīng)一種一種花費(fèi)一種收益 問擁有m元,令x為1到所有葉子(不含1)的路徑的點(diǎn)權(quán)和最小值

求x的最大值

一開始的想法是的定義dp[u][i][0/1]為u子樹花i元,u選或者不選的答案

但是后面會(huì)發(fā)現(xiàn)這樣定義狀態(tài)的話對(duì)于dp[u][i][1]的合并不是很好處理,因?yàn)槲覜]有記錄u選擇的是哪個(gè)方案

看了題解后學(xué)了一個(gè)新姿勢(shì)

定義dp[u][i]為u不選的時(shí)候花i元的最優(yōu)解

預(yù)處理一個(gè)w[u][i]表示u結(jié)點(diǎn)花i元最多能獲得的權(quán)值

考慮一個(gè)葉子結(jié)點(diǎn):dp[u][i]=w[u][i]

考慮一個(gè)非葉子結(jié)點(diǎn)不選時(shí)候:每一個(gè)兒子v加進(jìn)來的時(shí)候,狀態(tài)都分裂為dp[v][k]和dp[u][j-k]

對(duì)于每一個(gè)枚舉的k來說,答案是min(dp[v][k],dp[u][j-k]) 維護(hù)這個(gè)答案的最大值就是dp[u][j]

考慮完u不選的情況后,再對(duì)u單獨(dú)做一次背包,枚舉u的花費(fèi),取個(gè)最優(yōu)值就是答案

#include"cstdio" #include"queue" #include"cmath" #include"stack" #include"iostream" #include"algorithm" #include"cstring" #include"queue" #include"map" #include"set" #include"vector" #include"bitset" #define LL long long #define ull unsigned long long #define mems(a,b) memset(a,b,sizeof(a)) #define mdzz int mid=(L+R)>>1 #pragma comment(linker, "/STACK:1024000000,1024000000") using namespace std;const int N = 1e3+5; const int M = 205; const LL MOD = 998244353; const int INF = 0x3f3f3f3f;struct node{int e,next;node(){}node(int a,int b):e(a),next(b){} }edge[N<<1];int tot; int first[N],dp[N][M],kind[N],chose[N][M];void init(){tot=0;mems(first,-1);mems(dp,INF);mems(chose,0); }void addedge(int u,int v){edge[tot]=node(v,first[u]);first[u]=tot++;edge[tot]=node(u,first[v]);first[v]=tot++; }int T,n,m;void dfs1(int u,int fa){int f=0;for(int i=first[u];i!=-1;i=edge[i].next){int v=edge[i].e;if(v==fa) continue;dfs1(v,u);f++;for(int j=m;j>=0;j--){int tmp=0;for(int k=0;k<=j;k++) tmp=max(tmp,min(dp[u][j-k],dp[v][k]));dp[u][j]=tmp;}}if(!f){for(int i=0;i<=m;i++) dp[u][i]=chose[u][i];return;}for(int j=m;j>=0;j--)for(int k=0;k<=j;k++) dp[u][j]=max(dp[u][j],dp[u][j-k]+chose[u][k]); }int main(){//freopen("in.txt","r",stdin);scanf("%d",&T);while(T--){init();scanf("%d",&n);int u,v,k;for(int i=1;i<n;i++){scanf("%d%d",&u,&v);addedge(u,v);}scanf("%d",&m);for(int i=1;i<=n;i++){scanf("%d",&k);for(int j=1;j<=k;j++){scanf("%d%d",&u,&v);chose[i][u]=max(chose[i][u],v);}for(int j=1;j<=m;j++) chose[i][j]=max(chose[i][j],chose[i][j-1]);}dfs1(1,-1);printf("%d\n",dp[1][m]);}return 0; } View Code

?19.HDU 5758

題意:點(diǎn)有點(diǎn)權(quán)邊有花費(fèi),點(diǎn)權(quán)只能獲得一次,花費(fèi)每次經(jīng)過都要扣除,可以走回頭路,問能拿到的最大價(jià)值

參考Apple Tree可以知道需要加一維[0/1]表示是否回到u

定義dp[u][0/1]表示從u出發(fā)不回/回到u的最優(yōu)解

求一個(gè)結(jié)點(diǎn)對(duì)于整棵樹的信息一般都是先處理子樹內(nèi)的信息,再第二次dfs處理父親對(duì)答案的影響

先考慮子樹內(nèi):

考慮一個(gè)葉子結(jié)點(diǎn):dp[u][0]=dp[u][1]=w[u]

考慮一個(gè)非葉子u和他的一個(gè)兒子v:

對(duì)于dp[u][0]來說,v的貢獻(xiàn)只能是dp[v][0]-2*w[u,v],如果這個(gè)值小于0我必然不走v

對(duì)于dp[u][1]來說,如果不停在v內(nèi),v的貢獻(xiàn)也是dp[v][0]-2*w[u,v],如果停在u則狀態(tài)分裂為dp[u][0]+dp[v][1]-w[u,v]

再考慮fa對(duì)u的影響

考慮fa對(duì)u的影響時(shí)一般需要把u對(duì)fa的影響先排除

對(duì)于dp[fa][0]來說u的影響只能是max(0,dp[u][0]-2*w[fa,u]),直接減去就行了

對(duì)于dp[fa][1]來說有兩種情況

若最終不停在u,則和dp[fa][0]一樣處理

若停在u,則需要對(duì)fa再做一次排除u后的背包

這里將fa對(duì)u的影響作為參數(shù)下傳,為的是保證在推u的時(shí)候fa的值是對(duì)于整棵樹的,而其余結(jié)點(diǎn)是對(duì)于其子樹的

之所以這樣做是因?yàn)橛胒a更新u的時(shí)候,排除u對(duì)fa的影響之后fa相當(dāng)于u的一棵新子樹

#include"cstdio" #include"queue" #include"cmath" #include"stack" #include"iostream" #include"algorithm" #include"cstring" #include"queue" #include"map" #include"set" #include"vector" #include"bitset" #define LL long long #define ull unsigned long long #define mems(a,b) memset(a,b,sizeof(a)) #define mdzz int mid=(L+R)>>1 #pragma comment(linker, "/STACK:1024000000,1024000000") using namespace std;const int N = 1e5+50; const int M = N<<1; const LL MOD = 998244353; const int INF = 0x3f3f3f3f;struct node{int e,next,w;node(){}node(int a,int b,int c):e(a),next(b),w(c){} }edge[N<<1];int tot,n,m; int first[N],dp[N][2],w[N],id[N];void init(){tot=0;for(int i=1;i<=n;i++) first[i]=-1; }void addedge(int u,int v,int W){edge[tot]=node(v,first[u],W);first[u]=tot++;edge[tot]=node(u,first[v],W);first[v]=tot++; }void dfs1(int u,int fa){dp[u][0]=dp[u][1]=w[u];id[u]=-1;for(int i=first[u];i!=-1;i=edge[i].next){int v=edge[i].e;if(v==fa) continue;dfs1(v,u);int tmp=max(0,dp[v][0]-2*edge[i].w);dp[u][1]+=tmp;if(dp[u][1]<dp[u][0]+max(0,dp[v][1]-edge[i].w)){dp[u][1]=dp[u][0]+max(0,dp[v][1]-edge[i].w);id[u]=v;}dp[u][0]+=tmp;} } int ans[N]; void dfs2(int u,int fa,int f0,int f1){int t[2]={dp[u][0],dp[u][1]};int idd=id[u];t[1]+=f0;if(t[1]<t[0]+f1){t[1]=t[0]+f1;idd=fa;}t[0]+=f0;ans[u]=max(t[0],t[1]);for(int i=first[u];i!=-1;i=edge[i].next){int v=edge[i].e;if(v==fa) continue;if(v==idd){int tmp0=w[u]+f0,tmp1=w[u]+f1;for(int k=first[u];k!=-1;k=edge[k].next){int vv=edge[k].e;if(vv==fa||vv==v) continue;int tmp=max(0,dp[vv][0]-2*edge[k].w);tmp1+=tmp;tmp1=max(tmp1,tmp0+max(0,dp[vv][1]-edge[k].w));tmp0+=tmp;}tmp0=max(0,tmp0-2*edge[i].w);tmp1=max(0,tmp1-edge[i].w);dfs2(v,u,tmp0,tmp1);}else{int tmp=max(0,dp[v][0]-2*edge[i].w);int tmp0=max(0,t[0]-tmp-2*edge[i].w);int tmp1=max(0,t[1]-tmp-edge[i].w);dfs2(v,u,tmp0,tmp1);}} }int T,u,v,W,cas=1;int main(){//freopen("in.txt","r",stdin);//freopen("pending.txt","w",stdout);scanf("%d",&T);while(T--){scanf("%d",&n);init();for(int i=1;i<=n;i++) scanf("%d",&w[i]);for(int i=1;i<n;i++){scanf("%d%d%d",&u,&v,&W);addedge(u,v,W);}dfs1(1,-1);dfs2(1,-1,0,0);printf("Case #%d:\n",cas++);for(int i=1;i<=n;i++) printf("%d\n",ans[i]);}return 0; } View Code

?20.NUBT 1638

題意:建圖略麻煩,抽象出來就是說樹中選m個(gè)結(jié)點(diǎn),其中rt到每一個(gè)葉子的路徑上被選的結(jié)點(diǎn)數(shù)不超過k,問獲得的最大權(quán)值是多少

定義dp[u][i][j][0/1]表示u子樹選i個(gè),最多的路徑選了j個(gè),u選/不選

dp值全部初始化為-1表示不合法狀態(tài)

考慮一個(gè)葉子結(jié)點(diǎn):選的話是dp[u][1][1][1]=w[u] ?不選dp[u][0][0][0]=0

考慮一個(gè)非葉子結(jié)點(diǎn)u和他的一個(gè)兒子v:

對(duì)于狀態(tài)dp[u][i][j][0],可能轉(zhuǎn)移過來的狀態(tài)有dp[u][i-k][j][0]+dp[v][k][0~j][0/1]或者dp[u][i-k][0~j][0]+dp[v][k][j][0/1]

對(duì)于狀態(tài)dp[u][i][j][1],有dp[u][i-k][j][1]+dp[v][k][0~j-1][0/1]或dp[u][i-k][0~j][1]+dp[v][k][j-1][0/1](之所以v是j-1為上限是因?yàn)閡選了的話合并后v的最長鏈長度必然+1,這樣做是為了限制最長鏈在j范圍內(nèi))

#include"cstdio" #include"queue" #include"cmath" #include"stack" #include"iostream" #include"algorithm" #include"cstring" #include"queue" #include"map" #include"set" #include"vector" #include"bitset" #define LL long long #define ull unsigned long long #define mems(a,b) memset(a,b,sizeof(a)) #define mdzz int mid=(L+R)>>1 #pragma comment(linker, "/STACK:1024000000,1024000000") using namespace std;const int N = 120; const int M = N<<1; const LL MOD = 998244353; const int INF = 0x3f3f3f3f;struct Point{int x,y; }p[N<<2];bool cmp(Point a,Point b){return a.x<b.x; }struct Node{int y,l,r; }point[N];bool cmp1(Node a,Node b){if(a.y==b.y) return a.l<b.l;return a.y>b.y; }struct node{int e,next; }edge[N<<1];int first[N],cnt,tot; int dp[N][N][11][2],w[N],sz[N];void init(){tot=0;cnt=0;mems(first,-1);mems(dp,-1); }void addedge(int u,int v){edge[tot]=(node){v,first[u]};first[u]=tot++; }void build(int l,int r,int fa){for(int i=l+1;i<=r;i++){if(p[l].y==p[i].y){addedge(fa,++cnt);w[cnt]=p[i].x-p[l].x;//cout<<fa<<' '<<cnt<<' '<<w[cnt]<<endl;build(l+1,i-1,cnt);build(i,r,fa);return ;}else if(p[i].y>p[l].y){build(l+1,i-1,fa);build(i,r,fa);}} }int n,m,K;void dfs(int u){dp[u][1][1][1]=w[u];dp[u][0][0][0]=0;sz[u]=1;for(int i=first[u];i!=-1;i=edge[i].next){int v=edge[i].e;dfs(v);sz[u]+=sz[v];for(int j=sz[u];j>=0;j--)for(int k=0;k<=K;k++)for(int p=0;p<=min(sz[v],j);p++)for(int kk=0;kk<=k;kk++){if(dp[u][j-p][k][0]!=-1&&(dp[v][p][kk][0]!=-1||dp[v][p][kk][1]!=-1))dp[u][j][k][0]=max(dp[u][j][k][0],dp[u][j-p][k][0]+max(dp[v][p][kk][0],dp[v][p][kk][1]));if(dp[u][j-p][kk][0]!=-1&&(dp[v][p][k][0]!=-1||dp[v][p][k][1]!=-1))dp[u][j][k][0]=max(dp[u][j][k][0],dp[u][j-p][kk][0]+max(dp[v][p][k][0],dp[v][p][k][1]));if(kk>=1&&dp[u][j-p][k][1]!=-1&&(dp[v][p][kk-1][0]!=-1||dp[v][p][kk-1][1]!=-1))dp[u][j][k][1]=max(dp[u][j][k][1],dp[u][j-p][k][1]+max(dp[v][p][kk-1][0],dp[v][p][kk-1][1]));if(k>=1&&dp[u][j-p][kk][1]!=-1&&(dp[v][p][k-1][0]!=-1||dp[v][p][k-1][1]!=-1))dp[u][j][k][1]=max(dp[u][j][k][1],dp[u][j-p][kk][1]+max(dp[v][p][k-1][0],dp[v][p][k-1][1]));}} }int cas=1;int main(){//freopen("in.txt","r",stdin);while(~scanf("%d%d%d",&n,&m,&K)){init();for(int i=1;i<=n;i++) scanf("%d%d",&p[i].x,&p[i].y);sort(p+1,p+1+n,cmp);build(1,n,0);int rt=0;dfs(rt);int ans=-1;for(int i=0;i<K;i++) ans=max(ans,dp[rt][m][i][0]);printf("Case %d: %d\n",cas++,ans);}return 0; } View Code

21.HDU 5758

題意:邊花費(fèi)1,可以從一個(gè)點(diǎn)瞬移到另一個(gè)點(diǎn),問瞬移次數(shù)最少的前提下遍歷所有邊的最小花費(fèi)

可以知道瞬移次數(shù)是(葉子數(shù)+1)/2

定義dp[u][0]為遍歷完u后的最小花費(fèi)(只是第一次dp,答案不一定是最終答案

考慮非葉子u和他的一個(gè)兒子v:

若v有偶數(shù)個(gè)兒子,則要在瞬移次數(shù)最少的情況下遍歷(u,v)這條邊,就必須有兩個(gè)結(jié)點(diǎn)和v外的結(jié)點(diǎn)配對(duì),所以(u,v)對(duì)答案貢獻(xiàn)2

同理奇數(shù)的時(shí)候貢獻(xiàn)1

如果總?cè)~子數(shù)是偶數(shù)那答案已經(jīng)出來了

但是如果總?cè)~子數(shù)是奇數(shù)這樣的答案可能會(huì) 偏大

其實(shí)奇數(shù)的情況就是在偶數(shù)的情況加了一條沒有分叉的單鏈

所以再定義dp[u][1]為遍歷u后的最小花費(fèi)(第二次dp,獨(dú)立與第一次dp

對(duì)于一個(gè)u,枚舉這條單鏈出現(xiàn)的兒子v:

如果這個(gè)兒子就是一條單鏈,并且u是這條單鏈的起點(diǎn),則dp[u][1]=min(dp[u][1],dp[u][0])

如果不是兒子v不是單鏈則把這條單鏈從v中剔除,則v中的葉子數(shù)的奇偶就變化了

dp[u][1]先減去dp[v][0],再減去奇偶變化的影響d,再加上單鏈存在與v的dp值dp[v][1],維護(hù)最優(yōu)解

最后若總?cè)~子數(shù)是偶數(shù)則取第一次dp的結(jié)果,否則取第二次的

#include"cstdio" #include"queue" #include"cmath" #include"stack" #include"iostream" #include"algorithm" #include"cstring" #include"queue" #include"map" #include"set" #include"vector" #include"bitset" #define LL long long #define ull unsigned long long #define mems(a,b) memset(a,b,sizeof(a)) #define mdzz int mid=(L+R)>>1 #pragma comment(linker, "/STACK:1024000000,1024000000") using namespace std;const int N = 1e5+5; const int M = N<<1; const LL MOD = 998244353; const int INF = 0x3f3f3f3f;struct node{int e,next; }edge[N<<1];int first[N],cnt,tot; LL dp[N][2]; int sz[N],deg[N];void init(){tot=0;mems(first,-1);mems(deg,0);mems(dp,INF); }void addedge(int u,int v){edge[tot]=(node){v,first[u]};first[u]=tot++;edge[tot]=(node){u,first[v]};first[v]=tot++; }void dfs(int u,int fa){dp[u][0]=0;sz[u]=0;int flag=0;for(int i=first[u];i!=-1;i=edge[i].next){int v=edge[i].e;if(v==fa) continue;flag++;dfs(v,u);sz[u]+=sz[v];dp[u][0]+=dp[v][0];if(sz[v]&1) dp[u][0]++;else dp[u][0]+=2;}for(int i=first[u];i!=-1;i=edge[i].next){int v=edge[i].e;if(v==fa) continue;if(flag>1&&sz[v]==1) dp[u][1]=min(dp[u][1],dp[u][0]);if(dp[v][1]==INF) continue;LL tmp=dp[u][0]-dp[v][0]+dp[v][1];if(sz[v]&1) tmp++;else tmp--;dp[u][1]=min(dp[u][1],tmp);}if(!flag) sz[u]=1; }int n,m,u,v,T;int main(){//freopen("in.txt","r",stdin);scanf("%d",&T);while(T--){init();scanf("%d",&n);for(int i=1;i<n;i++){scanf("%d%d",&u,&v);addedge(u,v);deg[v]++;deg[u]++;}int rt=1,cnt=0;for(int i=1;i<=n;i++) {if(deg[i]!=1)rt=i;else cnt++;}dfs(rt,-1);printf("%lld\n",dp[rt][cnt&1]);}return 0; } View Code

?22.codeforces Round #322(Div.2) F

題意:把葉子平分染成兩種顏色,其余點(diǎn)隨便染,求最少有對(duì)相鄰的點(diǎn)顏色不同 ?輸入保證葉子是偶數(shù)個(gè)

定義dp[u][i][0/1]表示u子樹染i個(gè)兒子0色,u染0/1色

這題經(jīng)典的地方在于葉子和非葉子的初始情況不一樣

先dp值全部賦INF表示不合法

對(duì)于葉子來說:dp[u][1][0]=0,dp[u][0][1]=0,其余兩個(gè)狀態(tài)不合法

考慮非葉子u:

非葉子u的顏色對(duì)第二維是沒影響的,所以dp[u][0][1]=dp[u][0][0]=0

由于這里是必須要選擇兒子的情況,之前有些題目是兒子可以不選

必須選的情況的處理方法有兩種,第一種是先強(qiáng)制放一種狀態(tài),再枚舉其他狀態(tài)看看是否更優(yōu),有就替換,沒有就保留原來的

或者說是用一個(gè)變量去存放兒子的最優(yōu)情況,然后把這個(gè)最優(yōu)情況強(qiáng)制合并到原狀態(tài)里

這里我采用的是第二種方法

#include"cstdio" #include"queue" #include"cmath" #include"stack" #include"iostream" #include"algorithm" #include"cstring" #include"queue" #include"map" #include"set" #include"vector" #include"bitset" #define LL long long #define ull unsigned long long #define mems(a,b) memset(a,b,sizeof(a)) #define mdzz int mid=(L+R)>>1 #pragma comment(linker, "/STACK:1024000000,1024000000") using namespace std;const int N = 5005; const int M = N<<1; const LL MOD = 998244353; const int INF = 0x3f3f3f3f;struct node{int e,next; }edge[N<<1];int first[N],tot; int dp[N][N][2],deg[N],leaf[N];void init(){tot=0;mems(first,-1);mems(dp,INF);mems(deg,0); }void addedge(int u,int v){edge[tot]=(node){v,first[u]};first[u]=tot++;edge[tot]=(node){u,first[v]};first[v]=tot++; }int n,u,v;void dfs(int u,int fa){dp[u][0][1]=0;dp[u][0][0]=0;leaf[u]=0;int flag=0;for(int i=first[u];i!=-1;i=edge[i].next){int v=edge[i].e;if(v==fa) continue;dfs(v,u);flag=1;leaf[u]+=leaf[v];for(int j=leaf[u];j>=0;j--){int miv[2]={INF,INF};for(int k=0;k<=min(leaf[v],j);k++){miv[0]=min(miv[0],min(dp[u][j-k][0]+dp[v][k][1]+1,dp[u][j-k][0]+dp[v][k][0]));miv[1]=min(miv[1],min(dp[u][j-k][1]+dp[v][k][1],dp[u][j-k][1]+dp[v][k][0]+1));}dp[u][j][0]=miv[0];dp[u][j][1]=miv[1];}}if(!flag){leaf[u]=1;dp[u][0][0]=INF;dp[u][1][0]=0;} }int main(){init();scanf("%d",&n);for(int i=1;i<n;i++){scanf("%d%d",&u,&v);addedge(u,v);deg[v]++;deg[u]++;}if(n==2) return 0*puts("1");int rt,cnt=0;for(int i=1;i<=n;i++){if(deg[i]!=1) rt=i;else cnt++;}dfs(rt,-1);//for(int i=1;i<=n;i++)//for(int j=0;j<=leaf[i];j++) printf("i_%d j_%d %d %d\n",i,j,dp[i][j][0],dp[i][j][1]);printf("%d\n",min(dp[rt][cnt/2][0],dp[rt][cnt/2][1]));return 0; } View Code

23.COJ 1793

題意:對(duì)于每個(gè)點(diǎn)給一個(gè)限制xi表示xi選了才能選i,現(xiàn)在最多選m個(gè)人,問在這些限制下最多能選幾個(gè)

如果連邊(xi->i)一眼看過去結(jié)構(gòu)很像樹,因?yàn)槊總€(gè)結(jié)點(diǎn)只有一個(gè)父親

但是這里可能會(huì)構(gòu)成強(qiáng)聯(lián)通分量

不過很容易想到把強(qiáng)聯(lián)通分量縮點(diǎn)后也是可以構(gòu)成樹或者森林的

森林我們可以建立一個(gè)虛根0來合并成一棵樹

一開始有個(gè)地方?jīng)]想明白,就是對(duì)于一個(gè)強(qiáng)聯(lián)通分量來說可能去掉一個(gè)點(diǎn)后還是強(qiáng)聯(lián)通分量,所以一個(gè)強(qiáng)聯(lián)通分量內(nèi)我選擇幾個(gè)人是不好判斷的

但是仔細(xì)想想題目給的條件,每個(gè)點(diǎn)的入度只能為1,而這樣構(gòu)成的強(qiáng)聯(lián)通分量只能是一個(gè)簡單環(huán)

而對(duì)于一個(gè)簡單環(huán)來說我只能全取或者全不取

所以問題就轉(zhuǎn)化為了一個(gè)m的背包,每個(gè)點(diǎn)的sz即使花費(fèi)也是價(jià)值,問能拿到的最大價(jià)值是多少

這里有個(gè)地方需要變通

這里是選了父親才能選擇兒子,所以對(duì)于一個(gè)結(jié)點(diǎn)u以及他的兒子v來說,我要把v加進(jìn)來我首先得保證u被選

所以我枚舉v的容量k的時(shí)候始終保證j-k也就是剩余的容量始終是大于sz[u]的,這樣就能保證u始終被選

#include"cstdio" #include"queue" #include"cmath" #include"stack" #include"iostream" #include"algorithm" #include"cstring" #include"queue" #include"map" #include"set" #include"vector" #include"bitset" #define LL long long #define ull unsigned long long #define mems(a,b) memset(a,b,sizeof(a)) #define mdzz int mid=(L+R)>>1 #pragma comment(linker, "/STACK:1024000000,1024000000") using namespace std;const int N = 1e3+5; const int M = N<<1; const LL MOD = 998244353; const int INF = 0x3f3f3f3f;struct node{int s,e,next; }edge[M];int tot,id; int first[N]; int block,tp,n,m; int low[N],dfn[N],ins[N],deg[N]; int st[N],belong[N],sz[N]; int dp[N][N];void init(int n){tot=0;tp=0;block=0;id=0;for(int i=0;i<=n;i++){first[i]=-1;dfn[i]=0;ins[i]=0;deg[i]=0;for(int j=0;j<=m;j++) dp[i][j]=0;} }void addedge(int u,int v){edge[tot]=(node){u,v,first[u]};first[u]=tot++;//edge[tot]=(node){u,first[v]};//first[v]=tot++; }void tarjan(int u){low[u]=dfn[u]=++id;ins[u]=1;st[++tp]=u;for(int i=first[u];i!=-1;i=edge[i].next){int v=edge[i].e;if(!dfn[v]){tarjan(v);low[u]=min(low[u],low[v]);}else if(ins[v]) low[u]=min(low[u],dfn[v]);}if(low[u]==dfn[u]){block++;sz[block]=0;int v;do{v=st[tp--];ins[v]=0;belong[v]=block;sz[block]++;}while(v!=u);} }void rebuild(){int tot2=tot;tot=0;for(int i=0;i<=n;i++) first[i]=-1;for(int i=0;i<tot2;i++){int u=belong[edge[i].s];int v=belong[edge[i].e];if(u==v) continue;deg[v]++;addedge(u,v);} }void dfs(int u,int fa){for(int i=sz[u];i<=m;i++) dp[u][i]=sz[u];for(int i=first[u];i!=-1;i=edge[i].next){int v=edge[i].e;if(v==fa) continue;dfs(v,u);for(int j=m;j>=sz[u];j--)for(int k=0;k<=j-sz[u];k++)dp[u][j]=max(dp[u][j],dp[v][k]+dp[u][j-k]);} } int u;int main(){//freopen("in.txt","r",stdin);while(~scanf("%d%d",&n,&m)){init(n);for(int i=1;i<=n;i++){scanf("%d",&u);addedge(u,i);}for(int i=1;i<=n;i++) if(!dfn[i]) tarjan(i);rebuild();int rt=0;sz[0]=0;for(int i=1;i<=block;i++) if(!deg[i]) addedge(rt,i);dfs(rt,-1);printf("%d\n",dp[rt][m]==-1?0:dp[rt][m]);}return 0; } View Code

?

轉(zhuǎn)載于:https://www.cnblogs.com/luxiaoming/p/5824297.html

總結(jié)

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

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

精品 日韩 国产 欧美 视频 | 牛和人交xxxx欧美 | 久久久久亚洲精品男人的天堂 | 国内精品人妻无码久久久影院蜜桃 | 亚洲一区二区三区播放 | 亚洲熟妇自偷自拍另类 | 亚洲日韩乱码中文无码蜜桃臀网站 | 国产精品国产三级国产专播 | 老熟女重囗味hdxx69 | 中文字幕 人妻熟女 | 野外少妇愉情中文字幕 | 曰本女人与公拘交酡免费视频 | 久久久久久久人妻无码中文字幕爆 | 国产av无码专区亚洲a∨毛片 | 2020久久超碰国产精品最新 | 少妇高潮喷潮久久久影院 | 亚洲毛片av日韩av无码 | 国产精品无码mv在线观看 | 国模大胆一区二区三区 | 婷婷综合久久中文字幕蜜桃三电影 | 欧美成人免费全部网站 | 亚洲日本一区二区三区在线 | 亚洲小说春色综合另类 | aa片在线观看视频在线播放 | 四虎国产精品一区二区 | 成年女人永久免费看片 | 中文字幕 亚洲精品 第1页 | 欧美亚洲日韩国产人成在线播放 | 久久精品99久久香蕉国产色戒 | 欧美精品一区二区精品久久 | 人人妻人人澡人人爽人人精品浪潮 | 国产成人无码av片在线观看不卡 | 久久国产精品_国产精品 | 永久免费精品精品永久-夜色 | 欧美人与禽猛交狂配 | 无码帝国www无码专区色综合 | 乌克兰少妇xxxx做受 | 人妻熟女一区 | 久久精品国产日本波多野结衣 | 麻豆av传媒蜜桃天美传媒 | 黑人粗大猛烈进出高潮视频 | 老熟妇仑乱视频一区二区 | 超碰97人人做人人爱少妇 | 国产成人精品视频ⅴa片软件竹菊 | 国产精品高潮呻吟av久久4虎 | 高清不卡一区二区三区 | 国产午夜福利100集发布 | 中文字幕无码av激情不卡 | 无码国产激情在线观看 | 日本精品少妇一区二区三区 | 曰韩无码二三区中文字幕 | 真人与拘做受免费视频一 | 色综合天天综合狠狠爱 | 色婷婷av一区二区三区之红樱桃 | 中国女人内谢69xxxx | 国产人妻人伦精品1国产丝袜 | 日欧一片内射va在线影院 | 国产偷抇久久精品a片69 | 99久久精品国产一区二区蜜芽 | 色五月五月丁香亚洲综合网 | 爆乳一区二区三区无码 | 人人妻人人澡人人爽人人精品 | 亚洲 a v无 码免 费 成 人 a v | 久久久久av无码免费网 | 欧美老人巨大xxxx做受 | 午夜无码区在线观看 | 亚洲精品一区二区三区婷婷月 | 丰满护士巨好爽好大乳 | 女人被爽到呻吟gif动态图视看 | 人妻人人添人妻人人爱 | 粗大的内捧猛烈进出视频 | 人人妻人人澡人人爽欧美一区 | 性啪啪chinese东北女人 | 亚洲熟妇色xxxxx欧美老妇 | 久久久精品欧美一区二区免费 | 老司机亚洲精品影院 | av小次郎收藏 | 欧美亚洲日韩国产人成在线播放 | 无人区乱码一区二区三区 | 四虎永久在线精品免费网址 | 内射老妇bbwx0c0ck | 天堂无码人妻精品一区二区三区 | 国产乱人伦app精品久久 国产在线无码精品电影网 国产国产精品人在线视 | 三上悠亚人妻中文字幕在线 | 国产一区二区三区四区五区加勒比 | 夜夜夜高潮夜夜爽夜夜爰爰 | 国产成人人人97超碰超爽8 | 日韩无码专区 | 无码乱肉视频免费大全合集 | 免费人成在线视频无码 | www国产亚洲精品久久网站 | 青青青爽视频在线观看 | 2020久久超碰国产精品最新 | 男人扒开女人内裤强吻桶进去 | 国产激情无码一区二区app | 日韩精品无码一本二本三本色 | 日产精品高潮呻吟av久久 | 成熟人妻av无码专区 | 精品久久久中文字幕人妻 | 免费国产黄网站在线观看 | 国产乱人伦偷精品视频 | 东北女人啪啪对白 | 少妇久久久久久人妻无码 | 欧美性生交xxxxx久久久 | 一本加勒比波多野结衣 | 国产午夜精品一区二区三区嫩草 | 亚洲欧美国产精品专区久久 | 国产两女互慰高潮视频在线观看 | 中文精品无码中文字幕无码专区 | 国产亚洲美女精品久久久2020 | 国产网红无码精品视频 | 六月丁香婷婷色狠狠久久 | 九九综合va免费看 | 日日摸日日碰夜夜爽av | 女人高潮内射99精品 | 日日鲁鲁鲁夜夜爽爽狠狠 | 国产精品久久福利网站 | 狠狠色色综合网站 | 亚洲欧洲中文日韩av乱码 | 亚洲一区二区观看播放 | 国产办公室秘书无码精品99 | 国产特级毛片aaaaaaa高清 | 国产亚洲精品久久久久久 | 青春草在线视频免费观看 | 国产精品自产拍在线观看 | 久久精品人妻少妇一区二区三区 | 亚洲欧美国产精品久久 | 亚洲欧美国产精品专区久久 | 精品国产国产综合精品 | 日韩少妇内射免费播放 | 中文字幕人成乱码熟女app | 国产午夜精品一区二区三区嫩草 | 成在人线av无码免观看麻豆 | 免费无码av一区二区 | 久久综合九色综合欧美狠狠 | 国产av久久久久精东av | 夜精品a片一区二区三区无码白浆 | 人人澡人人妻人人爽人人蜜桃 | 激情内射亚州一区二区三区爱妻 | 色老头在线一区二区三区 | 国产精品永久免费视频 | aⅴ亚洲 日韩 色 图网站 播放 | 亚洲大尺度无码无码专区 | 又大又黄又粗又爽的免费视频 | 高中生自慰www网站 | 久久久国产精品无码免费专区 | 亚洲欧美中文字幕5发布 | 国产精品自产拍在线观看 | 熟女少妇在线视频播放 | 永久黄网站色视频免费直播 | 精品夜夜澡人妻无码av蜜桃 | 最新国产乱人伦偷精品免费网站 | 性色av无码免费一区二区三区 | 亚洲国产精品一区二区美利坚 | 成年美女黄网站色大免费全看 | 久久久久99精品国产片 | 久久久久人妻一区精品色欧美 | 欧美日本免费一区二区三区 | 日韩亚洲欧美中文高清在线 | 55夜色66夜色国产精品视频 | 人人澡人摸人人添 | 成人免费视频视频在线观看 免费 | 久久zyz资源站无码中文动漫 | 2020久久香蕉国产线看观看 | 精品国精品国产自在久国产87 | 国产精品第一国产精品 | 久久久久成人精品免费播放动漫 | av无码久久久久不卡免费网站 | 色噜噜亚洲男人的天堂 | 国产 精品 自在自线 | 少妇性俱乐部纵欲狂欢电影 | 国产成人亚洲综合无码 | 亚洲a无码综合a国产av中文 | 少妇久久久久久人妻无码 | 久久久久免费看成人影片 | 国产尤物精品视频 | 夫妻免费无码v看片 | 人人澡人人妻人人爽人人蜜桃 | 亚洲熟女一区二区三区 | 国产一区二区三区精品视频 | 蜜桃视频插满18在线观看 | 麻豆国产丝袜白领秘书在线观看 | 一本久道久久综合狠狠爱 | 牲欲强的熟妇农村老妇女 | 久久亚洲国产成人精品性色 | 久久综合给久久狠狠97色 | √天堂资源地址中文在线 | 欧美日本精品一区二区三区 | 国产精品亚洲五月天高清 | 日韩欧美成人免费观看 | 国产农村妇女高潮大叫 | 夜夜夜高潮夜夜爽夜夜爰爰 | 日产精品高潮呻吟av久久 | 亚洲色在线无码国产精品不卡 | 亚洲精品成人av在线 | 国产亚洲欧美日韩亚洲中文色 | 图片区 小说区 区 亚洲五月 | 成 人 网 站国产免费观看 | 久激情内射婷内射蜜桃人妖 | 中文字幕人成乱码熟女app | 亚洲性无码av中文字幕 | 国产女主播喷水视频在线观看 | 性色av无码免费一区二区三区 | 成人欧美一区二区三区黑人免费 | 蜜桃av蜜臀av色欲av麻 999久久久国产精品消防器材 | 99视频精品全部免费免费观看 | 亚洲综合在线一区二区三区 | 亚洲一区二区三区在线观看网站 | 午夜精品久久久久久久 | 精品国产一区二区三区av 性色 | 女高中生第一次破苞av | 中文无码伦av中文字幕 | 久久无码人妻影院 | 成年美女黄网站色大免费视频 | 亚洲精品成人福利网站 | 欧美日韩视频无码一区二区三 | 99久久久国产精品无码免费 | 伦伦影院午夜理论片 | 国产猛烈高潮尖叫视频免费 | 色诱久久久久综合网ywww | 国产精品无套呻吟在线 | 午夜精品久久久久久久久 | 中文字幕久久久久人妻 | 午夜男女很黄的视频 | 99精品视频在线观看免费 | 无码精品人妻一区二区三区av | а√天堂www在线天堂小说 | 无码人妻丰满熟妇区五十路百度 | 国产精品美女久久久 | 欧美人与禽猛交狂配 | 午夜福利一区二区三区在线观看 | 好屌草这里只有精品 | 麻豆国产97在线 | 欧洲 | 日本丰满熟妇videos | 超碰97人人做人人爱少妇 | 成人影院yy111111在线观看 | 亚洲成av人片天堂网无码】 | 日本丰满护士爆乳xxxx | 无码国产乱人伦偷精品视频 | 亚洲国产精品无码一区二区三区 | 久久精品中文字幕一区 | 综合激情五月综合激情五月激情1 | 毛片内射-百度 | 永久免费精品精品永久-夜色 | 国产成人无码av片在线观看不卡 | 国产黄在线观看免费观看不卡 | 国产又爽又猛又粗的视频a片 | 国产综合在线观看 | 国产农村乱对白刺激视频 | 在线观看国产午夜福利片 | 国产精品人人爽人人做我的可爱 | 中文字幕乱码亚洲无线三区 | 国产尤物精品视频 | 国产av一区二区三区最新精品 | 精品国产aⅴ无码一区二区 | 波多野结衣一区二区三区av免费 | 三级4级全黄60分钟 | 国产美女精品一区二区三区 | 亚洲中文字幕在线无码一区二区 | 激情内射亚州一区二区三区爱妻 | 亚洲精品综合一区二区三区在线 | 国产免费久久精品国产传媒 | 我要看www免费看插插视频 | 荫蒂被男人添的好舒服爽免费视频 | 女人高潮内射99精品 | 亚洲中文字幕久久无码 | 久久久久99精品国产片 | 色偷偷人人澡人人爽人人模 | 国产一区二区三区影院 | 美女黄网站人色视频免费国产 | 国产亚洲精品久久久ai换 | 又大又硬又黄的免费视频 | 亚洲欧美色中文字幕在线 | 99久久精品午夜一区二区 | 欧美国产日韩久久mv | 久热国产vs视频在线观看 | 久久久久国色av免费观看性色 | 欧美激情内射喷水高潮 | 国产成人综合色在线观看网站 | 又粗又大又硬毛片免费看 | 久久这里只有精品视频9 | 成人试看120秒体验区 | 又紧又大又爽精品一区二区 | 亚洲国产av美女网站 | 亚洲精品久久久久中文第一幕 | 51国偷自产一区二区三区 | 国产成人精品无码播放 | 扒开双腿吃奶呻吟做受视频 | 成熟妇人a片免费看网站 | 日韩精品a片一区二区三区妖精 | 精品国偷自产在线 | 蜜桃无码一区二区三区 | 久久久久亚洲精品男人的天堂 | 欧美熟妇另类久久久久久不卡 | 中文字幕无码人妻少妇免费 | 国产乱人伦app精品久久 国产在线无码精品电影网 国产国产精品人在线视 | 乱人伦人妻中文字幕无码久久网 | 午夜福利不卡在线视频 | 一本精品99久久精品77 | 亚洲自偷自偷在线制服 | 天堂а√在线中文在线 | 国产日产欧产精品精品app | 粉嫩少妇内射浓精videos | 一本一道久久综合久久 | 欧美35页视频在线观看 | 亚洲欧美国产精品专区久久 | 久久久精品456亚洲影院 | 日韩视频 中文字幕 视频一区 | www国产亚洲精品久久久日本 | 动漫av一区二区在线观看 | 亚洲成色www久久网站 | 国产尤物精品视频 | 亚洲色成人中文字幕网站 | 人人爽人人澡人人人妻 | 亚洲欧洲日本无在线码 | 亚洲精品欧美二区三区中文字幕 | 在线 国产 欧美 亚洲 天堂 | 天天摸天天透天天添 | av人摸人人人澡人人超碰下载 | 欧美国产亚洲日韩在线二区 | 久久久久99精品成人片 | 国产一精品一av一免费 | 国产成人无码区免费内射一片色欲 | 欧美真人作爱免费视频 | 97久久国产亚洲精品超碰热 | 欧美日韩在线亚洲综合国产人 | 国产色在线 | 国产 | 国产午夜亚洲精品不卡 | 国产乱人偷精品人妻a片 | 国产两女互慰高潮视频在线观看 | 成熟女人特级毛片www免费 | 亚洲午夜无码久久 | 激情五月综合色婷婷一区二区 | 99视频精品全部免费免费观看 | 久久久av男人的天堂 | 又色又爽又黄的美女裸体网站 | 中文字幕无码视频专区 | 久久亚洲日韩精品一区二区三区 | 99久久婷婷国产综合精品青草免费 | 97久久精品无码一区二区 | 亚洲精品国产a久久久久久 | 国产女主播喷水视频在线观看 | 大乳丰满人妻中文字幕日本 | 疯狂三人交性欧美 | 97精品国产97久久久久久免费 | 亚洲日本va午夜在线电影 | 少女韩国电视剧在线观看完整 | 欧美日韩人成综合在线播放 | 无码精品人妻一区二区三区av | 人妻少妇精品无码专区二区 | 亚洲综合色区中文字幕 | 狠狠色噜噜狠狠狠7777奇米 | 亚洲va欧美va天堂v国产综合 | 女人被爽到呻吟gif动态图视看 | 一本精品99久久精品77 | 丰满少妇弄高潮了www | 久久天天躁狠狠躁夜夜免费观看 | 乱人伦人妻中文字幕无码 | 久久精品女人天堂av免费观看 | 日本一卡2卡3卡四卡精品网站 | 波多野结衣高清一区二区三区 | 亚洲人成网站免费播放 | 亚洲欧洲日本无在线码 | 国产精品-区区久久久狼 | 国产无遮挡又黄又爽免费视频 | 日本www一道久久久免费榴莲 | 国产午夜亚洲精品不卡 | √天堂资源地址中文在线 | 久久久国产一区二区三区 | 国产另类ts人妖一区二区 | aⅴ亚洲 日韩 色 图网站 播放 | 人妻少妇精品无码专区二区 | 国模大胆一区二区三区 | 国产精品嫩草久久久久 | 久热国产vs视频在线观看 | 51国偷自产一区二区三区 | 少妇无套内谢久久久久 | 国精产品一区二区三区 | 国产乱子伦视频在线播放 | 在线观看国产一区二区三区 | 精品一区二区三区波多野结衣 | 久久综合给合久久狠狠狠97色 | 国产亚洲欧美日韩亚洲中文色 | 国产真实乱对白精彩久久 | 99久久精品无码一区二区毛片 | 日韩成人一区二区三区在线观看 | 美女黄网站人色视频免费国产 | 成人无码影片精品久久久 | 97夜夜澡人人爽人人喊中国片 | 一区二区三区乱码在线 | 欧洲 | 在线精品国产一区二区三区 | 日日天干夜夜狠狠爱 | 婷婷五月综合缴情在线视频 | 久久久久久国产精品无码下载 | 国产suv精品一区二区五 | 亚洲小说图区综合在线 | 色五月五月丁香亚洲综合网 | 午夜精品久久久久久久 | 高潮毛片无遮挡高清免费 | 精品久久久无码人妻字幂 | 精品国偷自产在线 | 色欲综合久久中文字幕网 | 欧美日韩色另类综合 | 国产尤物精品视频 | 日韩人妻无码一区二区三区久久99 | 国产精品久久久久影院嫩草 | 性欧美疯狂xxxxbbbb | 99久久99久久免费精品蜜桃 | 日韩 欧美 动漫 国产 制服 | 99久久人妻精品免费二区 | 少妇被黑人到高潮喷出白浆 | 亚洲热妇无码av在线播放 | 国产午夜福利亚洲第一 | 欧美猛少妇色xxxxx | 鲁大师影院在线观看 | 激情内射亚州一区二区三区爱妻 | 风流少妇按摩来高潮 | 一本无码人妻在中文字幕免费 | 熟妇人妻无乱码中文字幕 | 日本又色又爽又黄的a片18禁 | 免费人成网站视频在线观看 | 日本熟妇浓毛 | 久久国产精品偷任你爽任你 | 麻豆国产人妻欲求不满 | 少妇久久久久久人妻无码 | 人妻少妇精品久久 | 人妻有码中文字幕在线 | 99久久精品国产一区二区蜜芽 | 国内丰满熟女出轨videos | 国产精品爱久久久久久久 | 骚片av蜜桃精品一区 | 国产亚洲人成a在线v网站 | 久久99热只有频精品8 | 日本护士毛茸茸高潮 | 伊在人天堂亚洲香蕉精品区 | 老司机亚洲精品影院无码 | 国产午夜无码精品免费看 | 97se亚洲精品一区 | 免费无码的av片在线观看 | 黑人大群体交免费视频 | 欧美人与禽zoz0性伦交 | 国产色xx群视频射精 | 国产电影无码午夜在线播放 | 黄网在线观看免费网站 | 老司机亚洲精品影院 | 最新国产麻豆aⅴ精品无码 | 日本高清一区免费中文视频 | 久久精品人妻少妇一区二区三区 | 亚洲毛片av日韩av无码 | 欧美人与禽猛交狂配 | 日本精品少妇一区二区三区 | 亚洲成在人网站无码天堂 | 色偷偷人人澡人人爽人人模 | 一本久久a久久精品vr综合 | 国产无遮挡又黄又爽免费视频 | 一本大道伊人av久久综合 | 无码福利日韩神码福利片 | 色狠狠av一区二区三区 | 久久久久免费精品国产 | 日本护士毛茸茸高潮 | 日韩亚洲欧美精品综合 | 久久97精品久久久久久久不卡 | 97精品国产97久久久久久免费 | 西西人体www44rt大胆高清 | 亚洲精品午夜国产va久久成人 | 欧美日本精品一区二区三区 | 台湾无码一区二区 | 久久99精品国产麻豆 | 秋霞特色aa大片 | 午夜男女很黄的视频 | 在线观看国产一区二区三区 | 性生交大片免费看l | 婷婷丁香五月天综合东京热 | 国产97人人超碰caoprom | 国产精品无码久久av | 午夜福利不卡在线视频 | 一区二区三区高清视频一 | 亚洲中文字幕成人无码 | 国产艳妇av在线观看果冻传媒 | 中文久久乱码一区二区 | 国产精品高潮呻吟av久久4虎 | 亚洲综合精品香蕉久久网 | 中文字幕人成乱码熟女app | 国产精品无套呻吟在线 | 蜜桃臀无码内射一区二区三区 | 好爽又高潮了毛片免费下载 | 色妞www精品免费视频 | 亚洲日韩乱码中文无码蜜桃臀网站 | 久久99精品国产麻豆蜜芽 | 又粗又大又硬又长又爽 | 性生交大片免费看l | 亚洲欧美精品aaaaaa片 | 大屁股大乳丰满人妻 | 久久国产精品偷任你爽任你 | 国产乱码精品一品二品 | 亚洲一区二区三区四区 | 成人精品视频一区二区三区尤物 | 国产乱码精品一品二品 | 99re在线播放 | 又黄又爽又色的视频 | 国产免费久久久久久无码 | 欧美35页视频在线观看 | 一区二区三区乱码在线 | 欧洲 | 亚洲精品一区国产 | 久久精品中文闷骚内射 | 四虎影视成人永久免费观看视频 | 最新国产乱人伦偷精品免费网站 | 欧美阿v高清资源不卡在线播放 | 欧美放荡的少妇 | 国产精品无码一区二区桃花视频 | 国产午夜福利100集发布 | 人人妻人人澡人人爽欧美精品 | 四虎国产精品一区二区 | 亚洲色欲色欲天天天www | 中文字幕无码日韩专区 | 九一九色国产 | 丁香啪啪综合成人亚洲 | 少妇无码av无码专区在线观看 | 久久久久亚洲精品中文字幕 | 精品亚洲韩国一区二区三区 | 在线观看欧美一区二区三区 | 一二三四社区在线中文视频 | 日日鲁鲁鲁夜夜爽爽狠狠 | 无码国产乱人伦偷精品视频 | 久久精品中文闷骚内射 | 国产成人综合在线女婷五月99播放 | 高中生自慰www网站 | 久久久久久久女国产乱让韩 | a片在线免费观看 | 亚洲精品久久久久久一区二区 | 亚洲综合无码久久精品综合 | 国产黑色丝袜在线播放 | 乱人伦人妻中文字幕无码久久网 | 亚洲色大成网站www国产 | 亚洲精品一区二区三区大桥未久 | 水蜜桃亚洲一二三四在线 | 国产69精品久久久久app下载 | 国产成人综合在线女婷五月99播放 | 国产av剧情md精品麻豆 | 亚洲а∨天堂久久精品2021 | 国产成人无码av片在线观看不卡 | 亚洲中文字幕乱码av波多ji | 精品厕所偷拍各类美女tp嘘嘘 | 国产精品久久国产三级国 | 天下第一社区视频www日本 | 久久久精品欧美一区二区免费 | 人妻无码久久精品人妻 | 波多野结衣aⅴ在线 | 国产农村妇女高潮大叫 | 青青草原综合久久大伊人精品 | 日韩亚洲欧美精品综合 | 国产亚洲欧美日韩亚洲中文色 | 日本丰满护士爆乳xxxx | 狠狠色噜噜狠狠狠7777奇米 | 无码国产激情在线观看 | 伊人色综合久久天天小片 | 亚洲爆乳精品无码一区二区三区 | 在线精品亚洲一区二区 | 色综合久久中文娱乐网 | 捆绑白丝粉色jk震动捧喷白浆 | 国产极品美女高潮无套在线观看 | 亚洲精品中文字幕久久久久 | 国产精品国产三级国产专播 | 亚洲一区二区三区播放 | 亚洲精品综合五月久久小说 | 少妇人妻偷人精品无码视频 | 无码人妻出轨黑人中文字幕 | 思思久久99热只有频精品66 | 色综合久久久久综合一本到桃花网 | 亚洲中文字幕无码中文字在线 | 色情久久久av熟女人妻网站 | 少妇高潮一区二区三区99 | 亚洲色欲色欲天天天www | 日本精品人妻无码77777 天堂一区人妻无码 | 国内精品久久毛片一区二区 | 初尝人妻少妇中文字幕 | 人妻aⅴ无码一区二区三区 | 国产99久久精品一区二区 | 国产综合久久久久鬼色 | 国产一区二区不卡老阿姨 | 5858s亚洲色大成网站www | 四虎国产精品一区二区 | 人妻互换免费中文字幕 | 国产又粗又硬又大爽黄老大爷视 | 男女性色大片免费网站 | 色综合久久88色综合天天 | 人妻插b视频一区二区三区 | 伊人久久大香线蕉av一区二区 | 国产精品久久久久久亚洲影视内衣 | 无码纯肉视频在线观看 | 亚洲最大成人网站 | 国产av无码专区亚洲a∨毛片 | 18无码粉嫩小泬无套在线观看 | 久青草影院在线观看国产 | 亚洲色www成人永久网址 | 性色欲网站人妻丰满中文久久不卡 | 无码乱肉视频免费大全合集 | 无码帝国www无码专区色综合 | 人妻体内射精一区二区三四 | 久9re热视频这里只有精品 | 网友自拍区视频精品 | 给我免费的视频在线观看 | aⅴ在线视频男人的天堂 | 波多野结衣一区二区三区av免费 | 激情国产av做激情国产爱 | 国内揄拍国内精品少妇国语 | 天海翼激烈高潮到腰振不止 | 中文字幕无码免费久久9一区9 | 特黄特色大片免费播放器图片 | 国产人妖乱国产精品人妖 | 国产三级精品三级男人的天堂 | 国产麻豆精品一区二区三区v视界 | 成 人影片 免费观看 | 伊人久久大香线蕉午夜 | 人妻人人添人妻人人爱 | 亚洲国产精品毛片av不卡在线 | 日韩av无码一区二区三区不卡 | 国语精品一区二区三区 | 国产成人人人97超碰超爽8 | 少妇性l交大片欧洲热妇乱xxx | 无套内谢的新婚少妇国语播放 | 熟妇女人妻丰满少妇中文字幕 | 永久黄网站色视频免费直播 | 亚洲国产精品美女久久久久 | 激情内射日本一区二区三区 | 领导边摸边吃奶边做爽在线观看 | 国语自产偷拍精品视频偷 | 色婷婷综合中文久久一本 | 亚洲欧美国产精品专区久久 | 国产三级久久久精品麻豆三级 | 永久免费观看美女裸体的网站 | 无码av免费一区二区三区试看 | 性做久久久久久久久 | 思思久久99热只有频精品66 | 午夜无码区在线观看 | 国产免费久久久久久无码 | 国产亚洲欧美日韩亚洲中文色 | 99精品视频在线观看免费 | a片免费视频在线观看 | 久久国产劲爆∧v内射 | 丰满少妇女裸体bbw | 青青草原综合久久大伊人精品 | 国产精品久久久久无码av色戒 | 国产人妻久久精品二区三区老狼 | 日本丰满护士爆乳xxxx | 国产麻豆精品精东影业av网站 | 国产亚洲日韩欧美另类第八页 | 未满成年国产在线观看 | a国产一区二区免费入口 | 乱码av麻豆丝袜熟女系列 | 中文精品久久久久人妻不卡 | 少妇厨房愉情理9仑片视频 | 18禁黄网站男男禁片免费观看 | 亚洲国产精品无码一区二区三区 | 岛国片人妻三上悠亚 | 男女下面进入的视频免费午夜 | 欧美日韩色另类综合 | 国产一区二区三区四区五区加勒比 | 国内揄拍国内精品少妇国语 | 亚洲色欲色欲天天天www | 日本精品少妇一区二区三区 | 午夜熟女插插xx免费视频 | 国产精品亚洲а∨无码播放麻豆 | 欧美丰满少妇xxxx性 | 久久精品一区二区三区四区 | 领导边摸边吃奶边做爽在线观看 | 亚洲精品国产品国语在线观看 | 国产午夜无码视频在线观看 | 99精品视频在线观看免费 | 高潮毛片无遮挡高清免费 | 国产无遮挡又黄又爽免费视频 | 欧美性猛交xxxx富婆 | 亚洲伊人久久精品影院 | 久久精品国产一区二区三区 | 无码人中文字幕 | 亚洲精品欧美二区三区中文字幕 | 亚洲成av人综合在线观看 | 亚洲国产精品久久人人爱 | 成人无码精品一区二区三区 | 麻豆av传媒蜜桃天美传媒 | 精品欧美一区二区三区久久久 | 成人欧美一区二区三区黑人 | 中文字幕无线码 | 欧美日韩人成综合在线播放 | 欧美老妇交乱视频在线观看 | 又湿又紧又大又爽a视频国产 | 精品国偷自产在线 | 亚洲国产精品久久久天堂 | 国产成人精品视频ⅴa片软件竹菊 | 精品厕所偷拍各类美女tp嘘嘘 | 国产sm调教视频在线观看 | 日本一卡2卡3卡4卡无卡免费网站 国产一区二区三区影院 | 久久亚洲a片com人成 | 99久久精品国产一区二区蜜芽 | 亚洲精品国产精品乱码视色 | 无码av最新清无码专区吞精 | 熟妇人妻无码xxx视频 | 乱人伦人妻中文字幕无码久久网 | 狠狠色色综合网站 | 久久午夜无码鲁丝片秋霞 | 曰韩少妇内射免费播放 | 97精品人妻一区二区三区香蕉 | 国产欧美精品一区二区三区 | 国产色精品久久人妻 | 亚欧洲精品在线视频免费观看 | 久久久中文久久久无码 | 日本xxxx色视频在线观看免费 | 久久99精品国产麻豆蜜芽 | 免费乱码人妻系列无码专区 | 麻豆av传媒蜜桃天美传媒 | 在线播放免费人成毛片乱码 | 国产人妻人伦精品1国产丝袜 | 日日碰狠狠丁香久燥 | 99国产精品白浆在线观看免费 | 欧美黑人性暴力猛交喷水 | 亚洲精品美女久久久久久久 | 在线亚洲高清揄拍自拍一品区 | 色综合天天综合狠狠爱 | 国产色精品久久人妻 | 亚洲成a人片在线观看无码3d | 中国女人内谢69xxxx | 亚洲欧美色中文字幕在线 | 内射白嫩少妇超碰 | 国产av无码专区亚洲a∨毛片 | 无码av最新清无码专区吞精 | 亚洲精品国产a久久久久久 | 一本大道伊人av久久综合 | 清纯唯美经典一区二区 | 99久久亚洲精品无码毛片 | 亚洲成a人片在线观看日本 | 欧美阿v高清资源不卡在线播放 | 久久久精品欧美一区二区免费 | 国内精品久久毛片一区二区 | 纯爱无遮挡h肉动漫在线播放 | 久久久久免费精品国产 | 成人影院yy111111在线观看 | 天天爽夜夜爽夜夜爽 | 亚洲一区二区观看播放 | 久久成人a毛片免费观看网站 | 牛和人交xxxx欧美 | 欧美人与禽zoz0性伦交 | 国产一区二区三区精品视频 | 成 人影片 免费观看 | 成人精品视频一区二区三区尤物 | 亚洲成a人一区二区三区 | 久久精品99久久香蕉国产色戒 | 性欧美大战久久久久久久 | 中文字幕av日韩精品一区二区 | 亚洲人亚洲人成电影网站色 | 日日天日日夜日日摸 | 色综合久久中文娱乐网 | 亚洲国产精品一区二区第一页 | 熟妇女人妻丰满少妇中文字幕 | 欧美日韩亚洲国产精品 | 99久久精品日本一区二区免费 | 国产精品-区区久久久狼 | 亚洲人亚洲人成电影网站色 | 高清不卡一区二区三区 | 国产真实伦对白全集 | 国产69精品久久久久app下载 | 国内精品九九久久久精品 | 国产精品沙发午睡系列 | 国产又爽又黄又刺激的视频 | 欧美xxxxx精品 | 亚洲中文字幕乱码av波多ji | 女人色极品影院 | 国内精品人妻无码久久久影院蜜桃 | 97夜夜澡人人双人人人喊 | 性做久久久久久久免费看 | 少妇无套内谢久久久久 | 一本加勒比波多野结衣 | 国产av无码专区亚洲a∨毛片 | 精品 日韩 国产 欧美 视频 | 丝袜美腿亚洲一区二区 | 亚洲精品中文字幕乱码 | 99riav国产精品视频 | 自拍偷自拍亚洲精品被多人伦好爽 | 性色欲情网站iwww九文堂 | 国产亚洲精品久久久久久久 | 亚洲精品无码国产 | 精品国产成人一区二区三区 | 亚洲日韩av一区二区三区中文 | 99精品久久毛片a片 | 亲嘴扒胸摸屁股激烈网站 | 欧洲欧美人成视频在线 | 国产精品a成v人在线播放 | 无码人妻出轨黑人中文字幕 | 成熟人妻av无码专区 | 亚洲精品一区二区三区在线观看 | 一本无码人妻在中文字幕免费 | 天堂亚洲免费视频 | 人妻有码中文字幕在线 | 狠狠色丁香久久婷婷综合五月 | 久久伊人色av天堂九九小黄鸭 | 欧美熟妇另类久久久久久多毛 | 国产精品手机免费 | 久久亚洲a片com人成 | 欧美 亚洲 国产 另类 | 日本一区二区更新不卡 | 无码精品人妻一区二区三区av | 欧美xxxx黑人又粗又长 | 亚洲成色www久久网站 | 精品一区二区三区波多野结衣 | 亚洲国产综合无码一区 | 久久综合激激的五月天 | 伊人久久大香线蕉av一区二区 | 99麻豆久久久国产精品免费 | 国产精品对白交换视频 | 乱码午夜-极国产极内射 | 婷婷色婷婷开心五月四房播播 | 国产亚洲人成在线播放 | 日本一本二本三区免费 | 欧美自拍另类欧美综合图片区 | 国产精品亚洲五月天高清 | 午夜时刻免费入口 | 国产凸凹视频一区二区 | 日韩人妻少妇一区二区三区 | 亚拍精品一区二区三区探花 | 国产乡下妇女做爰 | 一本无码人妻在中文字幕免费 | 国产偷抇久久精品a片69 | 久久人人97超碰a片精品 | 国产精品久久久久久亚洲影视内衣 | 俺去俺来也在线www色官网 | 精品无码国产自产拍在线观看蜜 | 国产成人精品视频ⅴa片软件竹菊 | 无码国产乱人伦偷精品视频 | 88国产精品欧美一区二区三区 | 免费看男女做好爽好硬视频 | 国产成人av免费观看 | 国产九九九九九九九a片 | 少妇人妻大乳在线视频 | 精品久久综合1区2区3区激情 | 国内少妇偷人精品视频 | 国产麻豆精品精东影业av网站 | 熟妇人妻中文av无码 | 久久人人爽人人爽人人片ⅴ | 久9re热视频这里只有精品 | 精品午夜福利在线观看 | 国产无遮挡又黄又爽又色 | 国产精品永久免费视频 | 国产精品无码一区二区桃花视频 | 在教室伦流澡到高潮hnp视频 | 人妻体内射精一区二区三四 | 人人妻人人澡人人爽欧美一区九九 | www成人国产高清内射 | 久久国产自偷自偷免费一区调 | 乱中年女人伦av三区 | 亚洲国产精品久久人人爱 | 乌克兰少妇性做爰 | 免费男性肉肉影院 | 欧美 丝袜 自拍 制服 另类 | 午夜无码人妻av大片色欲 | 成人无码精品一区二区三区 | 老子影院午夜精品无码 | 国产精品亚洲а∨无码播放麻豆 | 内射白嫩少妇超碰 | 欧美激情一区二区三区成人 | 久久午夜无码鲁丝片 | 亚洲一区二区三区 | 亚洲日韩中文字幕在线播放 | 国产亚洲欧美日韩亚洲中文色 | 久久精品国产一区二区三区 | 18禁黄网站男男禁片免费观看 | 免费看男女做好爽好硬视频 | 丰满人妻精品国产99aⅴ | 最近中文2019字幕第二页 | 欧洲熟妇色 欧美 | 亚欧洲精品在线视频免费观看 | 日本高清一区免费中文视频 | 久久精品人妻少妇一区二区三区 | 亚洲国产一区二区三区在线观看 | 乱人伦人妻中文字幕无码久久网 | 激情亚洲一区国产精品 | www一区二区www免费 | 亚洲无人区午夜福利码高清完整版 | 欧美熟妇另类久久久久久多毛 | 国内少妇偷人精品视频免费 | 日本肉体xxxx裸交 | 牲欲强的熟妇农村老妇女视频 | 亚洲精品www久久久 | 国产综合色产在线精品 | 永久免费精品精品永久-夜色 | 老熟妇仑乱视频一区二区 | 一本久道久久综合婷婷五月 | 日韩精品成人一区二区三区 | 草草网站影院白丝内射 | 欧美日韩在线亚洲综合国产人 | 又粗又大又硬又长又爽 | 亚洲另类伦春色综合小说 | 日韩成人一区二区三区在线观看 | 久久久久av无码免费网 | 妺妺窝人体色www在线小说 | 麻豆精产国品 | 国产香蕉97碰碰久久人人 | 国产乱子伦视频在线播放 | 亚洲第一网站男人都懂 | 亚洲国产成人av在线观看 | 国产亚洲精品精品国产亚洲综合 | 成 人影片 免费观看 | 国产精品毛多多水多 | 丰满少妇弄高潮了www | 亚洲の无码国产の无码步美 | 国产亚洲精品久久久久久国模美 | 亚洲精品综合五月久久小说 | 国产亚洲精品久久久久久久久动漫 | 欧美丰满老熟妇xxxxx性 | 国产艳妇av在线观看果冻传媒 | 亚洲成av人综合在线观看 | 激情内射日本一区二区三区 | 亚洲gv猛男gv无码男同 | 精品无码一区二区三区爱欲 | 国产sm调教视频在线观看 | 欧美黑人性暴力猛交喷水 | 午夜无码区在线观看 | 色欲久久久天天天综合网精品 | 日韩无码专区 | 99久久久无码国产精品免费 | 在线视频网站www色 | 精品国产青草久久久久福利 | 图片区 小说区 区 亚洲五月 | 精品国产乱码久久久久乱码 | 亚洲乱亚洲乱妇50p | 国产精品二区一区二区aⅴ污介绍 | 久久久久亚洲精品中文字幕 | 国产成人精品视频ⅴa片软件竹菊 | 国产精品视频免费播放 | 一二三四在线观看免费视频 | 日本丰满护士爆乳xxxx | 超碰97人人射妻 | 国产疯狂伦交大片 | 日韩人妻少妇一区二区三区 | 日本护士xxxxhd少妇 | 精品国产一区二区三区av 性色 | 国产精华av午夜在线观看 | 国产性猛交╳xxx乱大交 国产精品久久久久久无码 欧洲欧美人成视频在线 | 天堂一区人妻无码 | 久久亚洲中文字幕精品一区 | 牛和人交xxxx欧美 | 大地资源网第二页免费观看 | 亚洲乱亚洲乱妇50p | 亚洲一区av无码专区在线观看 | 成人女人看片免费视频放人 | 国产精品va在线播放 | 欧美第一黄网免费网站 | 久久久国产精品无码免费专区 | 亚洲综合色区中文字幕 | 欧美第一黄网免费网站 | 好男人www社区 | 欧美黑人乱大交 | 一本色道婷婷久久欧美 | 亚洲精品国产第一综合99久久 | 三级4级全黄60分钟 | 色欲综合久久中文字幕网 | 水蜜桃色314在线观看 | 澳门永久av免费网站 | 天堂а√在线中文在线 | 亚洲va欧美va天堂v国产综合 | 成人试看120秒体验区 | 荫蒂被男人添的好舒服爽免费视频 | 国产亚洲精品久久久久久久久动漫 | 激情爆乳一区二区三区 | 日本大乳高潮视频在线观看 | 成人无码视频在线观看网站 | 欧美丰满熟妇xxxx性ppx人交 | 日本一卡2卡3卡4卡无卡免费网站 国产一区二区三区影院 | 亚洲七七久久桃花影院 | www一区二区www免费 | 亚洲爆乳精品无码一区二区三区 | 精品无码国产自产拍在线观看蜜 | 一本精品99久久精品77 | 成人免费无码大片a毛片 | 国产精品人人妻人人爽 | 中文字幕无码免费久久9一区9 | 无码人妻丰满熟妇区毛片18 | 日本熟妇乱子伦xxxx | 2019午夜福利不卡片在线 | 黑人巨大精品欧美黑寡妇 | 99精品国产综合久久久久五月天 | 精品无码国产一区二区三区av | av香港经典三级级 在线 | 国产农村妇女aaaaa视频 撕开奶罩揉吮奶头视频 | 丝袜美腿亚洲一区二区 | 国产成人无码区免费内射一片色欲 | 自拍偷自拍亚洲精品被多人伦好爽 | 久久伊人色av天堂九九小黄鸭 | 97人妻精品一区二区三区 | 国产片av国语在线观看 | 少妇性俱乐部纵欲狂欢电影 | 又粗又大又硬又长又爽 | 性欧美熟妇videofreesex | 欧美肥老太牲交大战 | 色偷偷人人澡人人爽人人模 | 99re在线播放 | 小sao货水好多真紧h无码视频 | 成熟妇人a片免费看网站 | 国产精品久久久久无码av色戒 | 国产精品久久久午夜夜伦鲁鲁 | 性色欲情网站iwww九文堂 | 久久久久se色偷偷亚洲精品av | 无码av岛国片在线播放 | 亚洲乱亚洲乱妇50p | 天天躁日日躁狠狠躁免费麻豆 | 久久国产自偷自偷免费一区调 | 乱人伦中文视频在线观看 | 女人被爽到呻吟gif动态图视看 | 人妻体内射精一区二区三四 | 日韩视频 中文字幕 视频一区 | 国内揄拍国内精品少妇国语 | 妺妺窝人体色www在线小说 | 中文字幕乱码人妻二区三区 | 久久伊人色av天堂九九小黄鸭 | 亚洲区小说区激情区图片区 | 18禁黄网站男男禁片免费观看 | 亚洲中文字幕久久无码 | 99久久人妻精品免费一区 | 老司机亚洲精品影院 | 亚洲中文字幕成人无码 | 中文精品无码中文字幕无码专区 | 中文字幕无码av波多野吉衣 | 熟妇人妻无乱码中文字幕 | 国产猛烈高潮尖叫视频免费 | 精品少妇爆乳无码av无码专区 | 中文字幕无码热在线视频 | 欧美精品在线观看 | 亚洲中文字幕乱码av波多ji | 强伦人妻一区二区三区视频18 | 丰满少妇人妻久久久久久 | 人妻少妇精品视频专区 | 日韩精品无码一本二本三本色 | 中文字幕中文有码在线 | 欧美一区二区三区视频在线观看 | 日韩av无码中文无码电影 | 三上悠亚人妻中文字幕在线 | 在线 国产 欧美 亚洲 天堂 | 精品少妇爆乳无码av无码专区 | 任你躁国产自任一区二区三区 | 欧美午夜特黄aaaaaa片 | 亚洲 a v无 码免 费 成 人 a v | 大乳丰满人妻中文字幕日本 | 亚洲狠狠婷婷综合久久 | 亚洲色大成网站www国产 | 中文无码成人免费视频在线观看 | 亚洲人成无码网www | 国产特级毛片aaaaaaa高清 | 无码人妻丰满熟妇区毛片18 | 亚洲午夜无码久久 | 国产午夜精品一区二区三区嫩草 | 亚洲欧洲中文日韩av乱码 | 少女韩国电视剧在线观看完整 | 亚洲精品国产精品乱码不卡 | 亚欧洲精品在线视频免费观看 | 久久久久久久久888 | 欧美日韩一区二区三区自拍 | 小泽玛莉亚一区二区视频在线 | 亚洲精品成人av在线 | 国产香蕉尹人综合在线观看 | 国产乱码精品一品二品 | 内射老妇bbwx0c0ck | 亚洲国产一区二区三区在线观看 | 人人妻人人澡人人爽精品欧美 | 亚洲精品久久久久中文第一幕 | 少妇一晚三次一区二区三区 | 国产97色在线 | 免 | 亚洲成a人一区二区三区 | 久久久久人妻一区精品色欧美 | 精品久久综合1区2区3区激情 | av在线亚洲欧洲日产一区二区 | 乱人伦人妻中文字幕无码 | 娇妻被黑人粗大高潮白浆 | 国产熟妇另类久久久久 | 少妇久久久久久人妻无码 | 特级做a爰片毛片免费69 | 丝袜美腿亚洲一区二区 | 欧美日韩视频无码一区二区三 | 亚洲国产精品久久久天堂 | 亚洲一区二区三区四区 | 中文字幕日韩精品一区二区三区 | 久久综合色之久久综合 | 日韩人妻无码中文字幕视频 | 天堂а√在线地址中文在线 | 国产高潮视频在线观看 | 国产午夜手机精彩视频 | 亚洲无人区午夜福利码高清完整版 | 久久人人爽人人爽人人片av高清 | 三上悠亚人妻中文字幕在线 | 又大又紧又粉嫩18p少妇 | 欧美 日韩 人妻 高清 中文 | 久青草影院在线观看国产 | 亚洲国产欧美国产综合一区 | 色婷婷久久一区二区三区麻豆 | 成熟妇人a片免费看网站 | 国产精品高潮呻吟av久久4虎 | 在线观看国产午夜福利片 | 天堂一区人妻无码 | 亚洲精品国偷拍自产在线麻豆 | 国产av一区二区精品久久凹凸 | 在线观看国产一区二区三区 | 亚洲高清偷拍一区二区三区 | 男女爱爱好爽视频免费看 | 国产午夜精品一区二区三区嫩草 | 日产精品99久久久久久 | 国产av一区二区三区最新精品 | 亚洲综合久久一区二区 | 国内揄拍国内精品人妻 | 国产亚洲欧美日韩亚洲中文色 | 国产亚洲精品久久久久久大师 | 欧美性黑人极品hd | 国产精品丝袜黑色高跟鞋 | 色综合久久久久综合一本到桃花网 | 久久亚洲精品中文字幕无男同 | 亚洲精品一区二区三区大桥未久 | 国产区女主播在线观看 | 大胆欧美熟妇xx | 初尝人妻少妇中文字幕 | www成人国产高清内射 | 精品少妇爆乳无码av无码专区 | 久久99精品久久久久久动态图 | 婷婷五月综合激情中文字幕 | 亚洲人成网站在线播放942 | 福利一区二区三区视频在线观看 | 东京热一精品无码av | 少妇性l交大片 | 色综合天天综合狠狠爱 | 任你躁国产自任一区二区三区 | 亚洲午夜久久久影院 | 国产精品嫩草久久久久 | 5858s亚洲色大成网站www | 一本久道久久综合狠狠爱 | 亚洲国产精品成人久久蜜臀 | 亚洲欧美国产精品专区久久 | 香港三级日本三级妇三级 | 国产精品人人爽人人做我的可爱 | 亚洲性无码av中文字幕 | www一区二区www免费 | 兔费看少妇性l交大片免费 | 亚洲精品成a人在线观看 | 亚洲一区二区三区偷拍女厕 | 乱码av麻豆丝袜熟女系列 | 免费人成在线观看网站 | 老熟妇乱子伦牲交视频 | 国产免费无码一区二区视频 | 无码人妻精品一区二区三区不卡 | 成人精品视频一区二区 | 亚洲精品一区二区三区在线 | 中文字幕+乱码+中文字幕一区 | 麻豆果冻传媒2021精品传媒一区下载 | 色婷婷av一区二区三区之红樱桃 | 国产精品第一国产精品 | 亚洲爆乳精品无码一区二区三区 | 丝袜人妻一区二区三区 | 精品欧洲av无码一区二区三区 | 国产欧美熟妇另类久久久 | 成人性做爰aaa片免费看不忠 | 黑人粗大猛烈进出高潮视频 | 骚片av蜜桃精品一区 | 免费无码肉片在线观看 | 天堂一区人妻无码 | 1000部夫妻午夜免费 | 强开小婷嫩苞又嫩又紧视频 | 国产精品欧美成人 | 美女张开腿让人桶 | 无码毛片视频一区二区本码 | 亚洲热妇无码av在线播放 | 亚洲 另类 在线 欧美 制服 | 国产精品理论片在线观看 | 成人精品视频一区二区三区尤物 | 久久成人a毛片免费观看网站 | 婷婷综合久久中文字幕蜜桃三电影 | 欧美性黑人极品hd | 亚洲大尺度无码无码专区 | 丰满妇女强制高潮18xxxx | 在线视频网站www色 | 中文字幕精品av一区二区五区 | 人妻少妇精品无码专区动漫 | 午夜嘿嘿嘿影院 | 人妻少妇精品视频专区 | 国产精品二区一区二区aⅴ污介绍 | 97无码免费人妻超级碰碰夜夜 | 欧洲熟妇精品视频 | 99国产精品白浆在线观看免费 | 最新版天堂资源中文官网 | 水蜜桃亚洲一二三四在线 | 欧美丰满熟妇xxxx性ppx人交 | 高清不卡一区二区三区 | 久久精品国产一区二区三区肥胖 | 欧美35页视频在线观看 | 网友自拍区视频精品 | 欧美 日韩 人妻 高清 中文 | 国产在热线精品视频 | 国产精品高潮呻吟av久久4虎 | 牲欲强的熟妇农村老妇女 | 激情人妻另类人妻伦 | 亚洲人成影院在线观看 | 国产真人无遮挡作爱免费视频 | 国产熟女一区二区三区四区五区 | 国产农村妇女高潮大叫 | 色综合视频一区二区三区 | 亚洲精品一区国产 | 国精产品一区二区三区 | 久久精品国产大片免费观看 | 国产人妻精品一区二区三区 | 天天摸天天碰天天添 | 成人欧美一区二区三区黑人 | 国产午夜无码视频在线观看 | 久久久久久久人妻无码中文字幕爆 | 99视频精品全部免费免费观看 | 最新国产麻豆aⅴ精品无码 | 亚洲高清偷拍一区二区三区 | 亚洲成熟女人毛毛耸耸多 | 中文字幕乱码亚洲无线三区 | 国产成人人人97超碰超爽8 | 在线亚洲高清揄拍自拍一品区 | 久久久中文久久久无码 | 强奷人妻日本中文字幕 | 日本精品久久久久中文字幕 | 中文精品无码中文字幕无码专区 | 99精品久久毛片a片 | 娇妻被黑人粗大高潮白浆 | 久久aⅴ免费观看 | 欧美肥老太牲交大战 | 一本久道高清无码视频 | 国产精品资源一区二区 | 中文字幕乱妇无码av在线 | 国产精品久久久久影院嫩草 | 夜夜夜高潮夜夜爽夜夜爰爰 | 老熟妇乱子伦牲交视频 | 久久精品成人欧美大片 | 成 人影片 免费观看 | 欧美国产日产一区二区 | 乱人伦人妻中文字幕无码 | 全球成人中文在线 | 99久久人妻精品免费一区 | 又大又黄又粗又爽的免费视频 | 亚洲乱码中文字幕在线 | 色五月丁香五月综合五月 | 午夜精品久久久久久久 | 一个人看的www免费视频在线观看 | 国产国产精品人在线视 | 午夜熟女插插xx免费视频 | 国产精品毛片一区二区 | 丁香花在线影院观看在线播放 | 亚洲自偷自偷在线制服 | 丝袜 中出 制服 人妻 美腿 | 亚洲精品久久久久avwww潮水 | 婷婷丁香六月激情综合啪 | 国产亚洲欧美在线专区 | 女高中生第一次破苞av | 欧美人与牲动交xxxx | 国产欧美熟妇另类久久久 | aa片在线观看视频在线播放 | 国产无遮挡吃胸膜奶免费看 | 欧美xxxx黑人又粗又长 | 日本大香伊一区二区三区 | 午夜理论片yy44880影院 | 国产精华av午夜在线观看 | 亚洲精品欧美二区三区中文字幕 | 一区二区三区乱码在线 | 欧洲 | 亚洲色欲久久久综合网东京热 | 久久精品中文字幕大胸 | 在线欧美精品一区二区三区 | 国产成人无码av在线影院 | 荫蒂被男人添的好舒服爽免费视频 | 日本熟妇乱子伦xxxx | 99视频精品全部免费免费观看 | 51国偷自产一区二区三区 | 国产精品二区一区二区aⅴ污介绍 | 成人免费视频视频在线观看 免费 | 免费观看又污又黄的网站 | 人妻少妇精品久久 | 少妇无码吹潮 | 精品无码国产一区二区三区av | av无码不卡在线观看免费 | 蜜臀av在线播放 久久综合激激的五月天 | 无遮挡啪啪摇乳动态图 | 好男人www社区 | 国产香蕉尹人视频在线 | 亚洲中文字幕av在天堂 | 久久无码中文字幕免费影院蜜桃 | 国产在线无码精品电影网 | 久久精品国产一区二区三区肥胖 | 少妇性l交大片欧洲热妇乱xxx | 色综合视频一区二区三区 | 国产激情无码一区二区 | 国产精品亚洲综合色区韩国 | 性欧美疯狂xxxxbbbb | 无码午夜成人1000部免费视频 | 青草视频在线播放 | 国产精品久久久久久久影院 | 东京一本一道一二三区 | 精品亚洲韩国一区二区三区 | 久久精品丝袜高跟鞋 | 日韩人妻少妇一区二区三区 | 久久久久久九九精品久 | 中文字幕无码日韩欧毛 | 全球成人中文在线 | 精品国产一区二区三区四区在线看 | 国产精品久久国产三级国 | 成人免费视频一区二区 | 又湿又紧又大又爽a视频国产 | 久久综合香蕉国产蜜臀av | 三上悠亚人妻中文字幕在线 | 久久人人爽人人爽人人片ⅴ | 中文字幕无码免费久久99 | 欧美日韩人成综合在线播放 | 色综合久久88色综合天天 | 国产偷抇久久精品a片69 | 亚洲一区av无码专区在线观看 | 国产亚洲精品久久久久久久久动漫 | 狠狠色丁香久久婷婷综合五月 | 巨爆乳无码视频在线观看 | 国产莉萝无码av在线播放 | 98国产精品综合一区二区三区 | 男女下面进入的视频免费午夜 | 久久精品人人做人人综合试看 | 亚洲色大成网站www国产 | 精品无码av一区二区三区 | 久激情内射婷内射蜜桃人妖 | 高潮毛片无遮挡高清免费 | 人人澡人摸人人添 | 日本精品人妻无码77777 天堂一区人妻无码 | 精品亚洲成av人在线观看 | 亚洲精品国产a久久久久久 | 国产区女主播在线观看 | 无码免费一区二区三区 | 无码播放一区二区三区 | av香港经典三级级 在线 | 99久久无码一区人妻 | 99riav国产精品视频 | 无遮挡啪啪摇乳动态图 | 夜夜高潮次次欢爽av女 | 九月婷婷人人澡人人添人人爽 | 97精品国产97久久久久久免费 | 东京一本一道一二三区 | 福利一区二区三区视频在线观看 | 亚洲狠狠色丁香婷婷综合 | 久久久久久av无码免费看大片 | 内射欧美老妇wbb | 无码帝国www无码专区色综合 | 色诱久久久久综合网ywww | 国产精品.xx视频.xxtv | 久久久中文久久久无码 | 天天摸天天碰天天添 | 亚洲午夜无码久久 | 亚洲国产高清在线观看视频 | 人妻与老人中文字幕 | 亚无码乱人伦一区二区 | 日韩欧美中文字幕在线三区 | 亚洲乱码中文字幕在线 | 无码人妻av免费一区二区三区 | 国产香蕉尹人综合在线观看 | 国内精品人妻无码久久久影院 | 日产精品高潮呻吟av久久 | 欧美人妻一区二区三区 | 色综合久久久无码中文字幕 | 成人精品一区二区三区中文字幕 | 成人欧美一区二区三区 | 人人澡人人妻人人爽人人蜜桃 | 国产人妖乱国产精品人妖 | 日本一区二区三区免费高清 | 国产精品沙发午睡系列 | 午夜性刺激在线视频免费 | 乱人伦人妻中文字幕无码久久网 | 97色伦图片97综合影院 | 久久久久成人片免费观看蜜芽 | 两性色午夜免费视频 | 我要看www免费看插插视频 | 动漫av一区二区在线观看 | 久久 国产 尿 小便 嘘嘘 | 国产精品人人爽人人做我的可爱 | 久久久久成人片免费观看蜜芽 | 乱人伦人妻中文字幕无码 | 熟妇人妻无乱码中文字幕 | 天堂久久天堂av色综合 | 曰韩少妇内射免费播放 | 男女超爽视频免费播放 | 麻豆国产人妻欲求不满谁演的 | 亚洲熟妇色xxxxx欧美老妇 | av无码久久久久不卡免费网站 | 亚洲七七久久桃花影院 | √天堂资源地址中文在线 | 国产精品久久国产精品99 | 亚洲精品成a人在线观看 | 少妇人妻av毛片在线看 | 男女性色大片免费网站 | 久久久久人妻一区精品色欧美 | 97se亚洲精品一区 | 波多野结衣av一区二区全免费观看 | 亚洲 a v无 码免 费 成 人 a v | 国产特级毛片aaaaaaa高清 | 水蜜桃色314在线观看 | 亚洲va中文字幕无码久久不卡 | 国产激情综合五月久久 | 免费播放一区二区三区 | 日日麻批免费40分钟无码 | 精品一区二区三区无码免费视频 | 久久国产精品精品国产色婷婷 | 亚洲の无码国产の无码步美 | 5858s亚洲色大成网站www | 鲁大师影院在线观看 | 欧美老妇与禽交 | 精品日本一区二区三区在线观看 | 激情五月综合色婷婷一区二区 | 在线观看国产午夜福利片 | 欧美xxxx黑人又粗又长 | 高中生自慰www网站 | 一本大道伊人av久久综合 | 精品欧洲av无码一区二区三区 | 蜜桃av蜜臀av色欲av麻 999久久久国产精品消防器材 | 成 人 网 站国产免费观看 | 亚洲一区二区三区四区 | 亚洲综合无码久久精品综合 | 久久97精品久久久久久久不卡 | 亚洲精品一区二区三区在线观看 | 欧美激情一区二区三区成人 | 精品国产乱码久久久久乱码 | 久久亚洲日韩精品一区二区三区 | 日韩人妻无码一区二区三区久久99 | 自拍偷自拍亚洲精品10p | 亚洲国产欧美日韩精品一区二区三区 | 帮老师解开蕾丝奶罩吸乳网站 | 少妇无码av无码专区在线观看 | 精品无人国产偷自产在线 | 亚洲国产精品久久久久久 | 日产精品高潮呻吟av久久 | 东京热无码av男人的天堂 | 高潮喷水的毛片 | 无码人妻丰满熟妇区毛片18 | 欧美激情一区二区三区成人 | 色婷婷久久一区二区三区麻豆 | 无遮挡啪啪摇乳动态图 | 丝袜人妻一区二区三区 | 玩弄少妇高潮ⅹxxxyw | 一本色道久久综合狠狠躁 | 99久久99久久免费精品蜜桃 | 无码人中文字幕 | 真人与拘做受免费视频 | 麻豆国产人妻欲求不满 | 久久久久成人片免费观看蜜芽 | 国产亚洲视频中文字幕97精品 | 久久综合激激的五月天 | 亚洲精品美女久久久久久久 | 大胆欧美熟妇xx | 久久精品无码一区二区三区 | 欧美日韩在线亚洲综合国产人 | 亚洲精品一区三区三区在线观看 | 丰满少妇熟乱xxxxx视频 | 5858s亚洲色大成网站www | 亚洲综合无码一区二区三区 | 人妻体内射精一区二区三四 | 国产在线精品一区二区三区直播 | 亚洲精品久久久久久一区二区 | 亚洲伊人久久精品影院 | 奇米综合四色77777久久 东京无码熟妇人妻av在线网址 | 波多野结衣高清一区二区三区 | 精品人妻中文字幕有码在线 | 亚洲熟女一区二区三区 | 熟妇人妻无码xxx视频 | 国产真实夫妇视频 | 亚洲色大成网站www | 日韩av激情在线观看 | 亚洲乱亚洲乱妇50p | 日韩人妻系列无码专区 | 亚洲精品无码国产 | 国产va免费精品观看 | 精品日本一区二区三区在线观看 | 婷婷五月综合激情中文字幕 | 成人片黄网站色大片免费观看 | 国产亚洲美女精品久久久2020 | 亚洲精品一区三区三区在线观看 | 中文字幕人成乱码熟女app | 国产精品人人妻人人爽 | 中文字幕无线码免费人妻 | 丰满少妇女裸体bbw | 国产精品无码一区二区桃花视频 | 国精产品一品二品国精品69xx | 亚洲色偷偷偷综合网 | 精品人妻人人做人人爽夜夜爽 | 特大黑人娇小亚洲女 | 丰满人妻精品国产99aⅴ | 日韩av无码一区二区三区不卡 | 久在线观看福利视频 | 亚洲成熟女人毛毛耸耸多 | 男女超爽视频免费播放 | 国产午夜福利亚洲第一 | 国产激情无码一区二区app | 性欧美牲交在线视频 | 夜夜夜高潮夜夜爽夜夜爰爰 | 狠狠色噜噜狠狠狠狠7777米奇 | 无码午夜成人1000部免费视频 | 男女性色大片免费网站 | 国产成人综合在线女婷五月99播放 | 日本大乳高潮视频在线观看 | 国产亚洲视频中文字幕97精品 | 亚洲日韩乱码中文无码蜜桃臀网站 | 欧美精品一区二区精品久久 | 国产成人人人97超碰超爽8 | 久久久久久亚洲精品a片成人 | 人人澡人摸人人添 | 精品人妻av区 | 欧美老妇与禽交 | 99久久亚洲精品无码毛片 | 成人片黄网站色大片免费观看 | 国产成人久久精品流白浆 | 亚洲精品午夜国产va久久成人 | 国产一区二区三区影院 | 熟女俱乐部五十路六十路av | 少妇激情av一区二区 | a国产一区二区免费入口 | 强伦人妻一区二区三区视频18 | 久久国产精品精品国产色婷婷 | 少妇的肉体aa片免费 | 3d动漫精品啪啪一区二区中 | 欧美喷潮久久久xxxxx | 一本色道婷婷久久欧美 | 精品人妻av区 | 国产美女精品一区二区三区 | 日本丰满熟妇videos | 亚洲成色www久久网站 | 国产精品资源一区二区 | 午夜理论片yy44880影院 | 国产内射老熟女aaaa | 亚洲欧洲无卡二区视頻 | 曰本女人与公拘交酡免费视频 | 欧美老熟妇乱xxxxx | 亚洲一区二区三区偷拍女厕 | 日本xxxx色视频在线观看免费 | 九九久久精品国产免费看小说 | 亚洲精品无码人妻无码 | 99re在线播放 | 国产成人一区二区三区在线观看 | 久久99国产综合精品 | 少妇太爽了在线观看 | 亚洲色大成网站www | 久久亚洲国产成人精品性色 | 欧美丰满老熟妇xxxxx性 | 最新版天堂资源中文官网 | 99riav国产精品视频 | 欧美老妇与禽交 | 中文无码精品a∨在线观看不卡 | www国产亚洲精品久久网站 | 丝袜足控一区二区三区 | 精品一区二区不卡无码av | 亚洲精品中文字幕 | 蜜桃av蜜臀av色欲av麻 999久久久国产精品消防器材 | 中文字幕亚洲情99在线 | 性做久久久久久久久 | 亚洲国产av美女网站 | 国产黄在线观看免费观看不卡 | 夜夜影院未满十八勿进 | 台湾无码一区二区 | 国产成人综合色在线观看网站 | 日本爽爽爽爽爽爽在线观看免 | 十八禁真人啪啪免费网站 | 国产成人精品久久亚洲高清不卡 | 久久国产精品偷任你爽任你 | 国产精品久久国产三级国 | 自拍偷自拍亚洲精品被多人伦好爽 | 日本大乳高潮视频在线观看 | 精品久久久无码中文字幕 | 国产高清不卡无码视频 | 麻豆蜜桃av蜜臀av色欲av | 久久aⅴ免费观看 | 亚洲精品成人福利网站 | 极品嫩模高潮叫床 | 高清无码午夜福利视频 | 乌克兰少妇xxxx做受 | a在线观看免费网站大全 | 两性色午夜视频免费播放 | 色偷偷人人澡人人爽人人模 | 色综合久久久无码网中文 | 狂野欧美性猛xxxx乱大交 | 人妻无码久久精品人妻 | 国产精品毛多多水多 | 东京热一精品无码av | 蜜桃av蜜臀av色欲av麻 999久久久国产精品消防器材 | 99精品无人区乱码1区2区3区 | 无码国产激情在线观看 | 无码国内精品人妻少妇 | 中文字幕 亚洲精品 第1页 | 无套内谢的新婚少妇国语播放 | 大肉大捧一进一出视频出来呀 | 精品偷拍一区二区三区在线看 | 国产精品久久久久久久影院 | 大乳丰满人妻中文字幕日本 | 国产精华av午夜在线观看 | 性色av无码免费一区二区三区 | 丝袜人妻一区二区三区 | 亚洲一区二区三区偷拍女厕 | 毛片内射-百度 | 日本护士毛茸茸高潮 | 中文字幕无码日韩专区 | 国产成人无码av在线影院 | 中文字幕人妻无码一区二区三区 | 亚洲精品一区二区三区四区五区 | 亚洲欧美日韩国产精品一区二区 | 国产精品久久久久影院嫩草 | 内射巨臀欧美在线视频 | 在线а√天堂中文官网 | 日本丰满熟妇videos | 无人区乱码一区二区三区 | 又粗又大又硬毛片免费看 | 人妻尝试又大又粗久久 | 亚洲国产欧美国产综合一区 | 俄罗斯老熟妇色xxxx | 中文字幕无码热在线视频 | 亚洲精品久久久久久一区二区 | 精品国产国产综合精品 | 成人三级无码视频在线观看 | 国产精品亚洲综合色区韩国 | 国产成人无码专区 | 亚洲小说图区综合在线 | 97无码免费人妻超级碰碰夜夜 | 日日碰狠狠丁香久燥 | 1000部啪啪未满十八勿入下载 | 国产精品人妻一区二区三区四 | 少妇被黑人到高潮喷出白浆 | 人妻有码中文字幕在线 | 给我免费的视频在线观看 | 亚洲中文字幕av在天堂 | 久久国内精品自在自线 | 狠狠亚洲超碰狼人久久 | 国产精品久久久久久久影院 | 欧美国产日韩亚洲中文 | 对白脏话肉麻粗话av | 欧洲熟妇色 欧美 | 亚洲熟妇自偷自拍另类 | 亚洲成av人综合在线观看 | 国产超碰人人爽人人做人人添 | 国产人妻人伦精品 | 日本一区二区更新不卡 | 亚洲区欧美区综合区自拍区 | 天堂无码人妻精品一区二区三区 | 日本熟妇大屁股人妻 | 麻豆果冻传媒2021精品传媒一区下载 | 欧美第一黄网免费网站 | 午夜福利不卡在线视频 | 国内精品人妻无码久久久影院蜜桃 | 最新国产麻豆aⅴ精品无码 | 国产精品久久国产精品99 | 纯爱无遮挡h肉动漫在线播放 | 久久久精品成人免费观看 | 久久久国产一区二区三区 | 久久国产精品萌白酱免费 | 全黄性性激高免费视频 | 亚洲综合久久一区二区 | 熟妇人妻激情偷爽文 | 国产福利视频一区二区 | 国产激情一区二区三区 | 人人妻在人人 | 一本色道久久综合狠狠躁 | 中文字幕无码人妻少妇免费 | 中国女人内谢69xxxx | 日本大乳高潮视频在线观看 | 午夜时刻免费入口 | 少妇邻居内射在线 | 精品人妻中文字幕有码在线 | 亚洲乱码日产精品bd | 麻豆蜜桃av蜜臀av色欲av | 亚洲区小说区激情区图片区 | 最新国产乱人伦偷精品免费网站 | av无码久久久久不卡免费网站 | 国产偷国产偷精品高清尤物 | 久久久久99精品国产片 | 全球成人中文在线 | 久久久久亚洲精品中文字幕 | 妺妺窝人体色www在线小说 | 草草网站影院白丝内射 | 欧美第一黄网免费网站 | 久久www免费人成人片 | 亚洲欧美精品伊人久久 | 久久aⅴ免费观看 | 国产精品99爱免费视频 | av人摸人人人澡人人超碰下载 | 国产精品igao视频网 | 日韩av无码一区二区三区不卡 |