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

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

2016团体程序设计天梯赛-决赛-部分题解

發布時間:2024/1/8 编程问答 48 豆豆
生活随笔 收集整理的這篇文章主要介紹了 2016团体程序设计天梯赛-决赛-部分题解 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

  題目鏈接:https://www.patest.cn/contests/gplt

  第一個卡的題是“到底是不是太胖了”,當時以為卡精度,因為各種eps都過不了。。但是結束后隊友說不卡精度,隨便一個eps就過了- -,可能是代碼寫搓了。但是更好的方法是全部變成整數做來規避精度的問題。具體見代碼:

1 #include <stdio.h> 2 #include <algorithm> 3 #include <string.h> 4 #include <vector> 5 #include <map> 6 #include <set> 7 #include <queue> 8 #include <iostream> 9 using namespace std; 10 const int inf = 0x3f3f3f3f; 11 typedef long long ll; 12 const int N = 500 + 5; 13 14 int main() 15 { 16 int T; 17 cin >> T; 18 while(T--) 19 { 20 int h,w; 21 cin >> h >> w; 22 int biaozhun = 2*(h-100); 23 if(w*100>biaozhun*9*9 && w*100<biaozhun*11*9) puts("You are wan mei!"); 24 else if(w*100>=biaozhun*11*9) puts("You are tai pang le!"); 25 else puts("You are tai shou le!"); 26 } 27 } View Code

?

  然后是紅色警報這題,一開始以為是和上次的刪邊并查集一樣,但是比賽時發現沒法做,比賽結束后倉鼠學長說可以并查集做,但是他沒有通過全部數據。。但是考慮到這題的數據范圍小,可以直接暴力做,每次刪除一個點就判斷一下連通分量數的變化即可。具體見代碼(細節比較多):

1 #include <stdio.h> 2 #include <algorithm> 3 #include <string.h> 4 #include <vector> 5 #include <map> 6 #include <set> 7 #include <queue> 8 #include <iostream> 9 using namespace std; 10 const int inf = 0x3f3f3f3f; 11 typedef long long ll; 12 const int N = 500 + 5; 13 14 vector<int> G[N]; 15 int root[N]; 16 bool vis[N],des[N]; 17 int findroot(int x) {return x==root[x]?x:root[x]=findroot(root[x]);} 18 int n,m,k; 19 20 void dfs(int x) 21 { 22 vis[x] = 1; 23 for(int i=0;i<G[x].size();i++) 24 { 25 int v = G[x][i]; 26 if(des[v] || vis[v]) continue; 27 dfs(v); 28 } 29 } 30 31 int getcnt() 32 { 33 int cnt = 0; 34 memset(vis,0,sizeof(vis)); 35 for(int i=0;i<n;i++) 36 { 37 if(!des[i] && !vis[i]) {dfs(i);cnt++; 38 //printf("%d !!\n",i); 39 } 40 } 41 return cnt; 42 } 43 44 int main() 45 { 46 while(scanf("%d%d",&n,&m)==2) 47 { 48 memset(des,false,sizeof(des)); 49 for(int i=1;i<=n;i++) G[i].clear(),root[i]=i; 50 for(int i=1;i<=m;i++) 51 { 52 int u,v; 53 scanf("%d%d",&u,&v); 54 G[u].push_back(v); 55 G[v].push_back(u); 56 } 57 int cnt = getcnt(); 58 scanf("%d",&k); 59 /*if(n==1 && k==1) 60 { 61 int t; 62 scanf("%d",&t); 63 printf("Red Alert: "); 64 printf("City %d is lost!\n",t); 65 printf("Game Over.\n"); 66 continue; 67 }*/ 68 for(int i=1;i<=k;i++) 69 { 70 int t; 71 scanf("%d",&t); 72 des[t] = 1; 73 int now = getcnt(); 74 if(G[t].size()==0) cnt--; 75 // 只有一個點的聯通分量被刪除,不會發生警報 76 //printf("%d %d !!\n",cnt,now); 77 78 //now = cnt; 79 if(now > cnt) 80 { 81 printf("Red Alert: "); 82 printf("City %d is lost!\n",t); 83 } 84 else printf("City %d is lost.\n",t); 85 if(now != cnt) cnt = now; // 存在有now小于cnt的可能性 86 87 if(i==n) printf("Game Over.\n"); 88 } 89 } 90 } View Code

  

  列車調度,比賽時想的方法是弄一個set數組,然后不斷的把新元素插入到可以插入的位置并且滿足這個元素比set的首元素小,比方說已經有的三個set是{7}{8}{9},那么新元素是4的話那么就插入到7的前面(如果不存在這樣的set就新開一個set),然后答案就是開的set的個數,不過這個方法有很大的問題,想了一下,如果存在多個可以放的位置,到底放哪個很難講清楚:舉個例子有集合{7}{9},我要插入4,應該是插在7后面比較好,因為這樣的話如果再插入一個元素8就可以放在9的后面不必新開set;如果4放9后,8就得新開set了。那么是不是如果有多個可以放的位置放在首元素最小的位置就可以了呢?這樣的話仍會超時,因為每次插入一個新的元素的復雜度是O(n)。

  所以,這題的正解是LIS。試想,這個題目的意思是,讓一個序列經過調度以后變成遞增的,那么需要調度的是這個序列里面原先遞減的部分,所以只要求原序列里面最長遞減子序列的長度即可,這個序列的每一個元素都需要放進一個軌道,然后原序列中遞增的元素按照原先的順序插入到能插入的位置即可,因為他們的相對位置是遞增,出來也一定是遞增的(其實這么一想的話和用set維護的原理還是差不多的)。然后,考慮道題目給的序列順序是從右到左的,因此求的是最長上升子序列的長度,即LIS。具體見代碼:

1 #include <stdio.h> 2 #include <algorithm> 3 #include <string.h> 4 #include <vector> 5 #include <map> 6 #include <set> 7 #include <queue> 8 #include <iostream> 9 using namespace std; 10 const int inf = 0x3f3f3f3f; 11 typedef long long ll; 12 const int N = (int)1e5 + 5; 13 14 int dp[N]; 15 16 int main() 17 { 18 int n; 19 while(scanf("%d",&n)==1) 20 { 21 memset(dp,inf,sizeof(dp)); 22 for(int i=0;i<n;i++) 23 { 24 int v; 25 scanf("%d",&v); 26 *lower_bound(dp,dp+n,v) = v; 27 } 28 printf("%d\n",lower_bound(dp,dp+n,inf)-dp); 29 } 30 } View Code

?

  二叉搜索樹那題,讓你判斷這棵樹是不是完全的二叉樹。雖然別人都說簡單,但是我不會寫二叉樹,所以這里也還是留個代碼吧:

1 #include <stdio.h> 2 #include <algorithm> 3 #include <string.h> 4 #include <vector> 5 #include <map> 6 #include <set> 7 #include <queue> 8 #include <iostream> 9 using namespace std; 10 const int inf = 0x3f3f3f3f; 11 typedef long long ll; 12 const int N = (int)1e6 + 5; 13 14 int tree[N]; 15 16 int main() 17 { 18 int n; 19 while(scanf("%d",&n)==1) 20 { 21 memset(tree,inf,sizeof(tree)); 22 int maxpos = 1; 23 for(int i=1;i<=n;i++) 24 { 25 int v; 26 scanf("%d",&v); 27 int pos = 1; 28 while(tree[pos] != inf) 29 { 30 if(v > tree[pos]) pos = pos << 1; 31 else pos = pos << 1 | 1; 32 } 33 tree[pos] = v; 34 maxpos = max(maxpos,pos); 35 } 36 37 /* 38 若設二叉樹的深度為h,除第 h 層外,其它各層 (1~h-1) 的結點數都達到最大個數, 39 第 h 層所有的結點都連續集中在最左邊,這就是完全二叉樹。 40 41 滿二叉樹:除葉子結點外的所有結點均有兩個子結點。節點數達到最大值。所有葉子結點必須在同一層上。 42 */ 43 int flag = 1,first = 1; 44 for(int i=1;i<=maxpos;i++) 45 { 46 if(tree[i] != inf) 47 { 48 if(first) 49 { 50 printf("%d",tree[i]); 51 first = 0; 52 } 53 else printf(" %d",tree[i]); 54 } 55 else flag = 0; 56 } 57 58 puts(""); 59 puts(flag?"YES":"NO"); 60 } 61 } View Code

?  

  愿天下有情人都是失散多年的兄妹,這題當時做的人挺少以為很難,其實還是比較簡單的,也不用什么LCA,直接暴力一下訪問5代就行了,但是有個坑點是,在建圖時對父母進行push_back的時候,父母的性別在這個時候也要設置好。具體見代碼:

1 #include <stdio.h> 2 #include <algorithm> 3 #include <string.h> 4 #include <vector> 5 #include <map> 6 #include <set> 7 #include <queue> 8 #include <iostream> 9 #include <stdlib.h> 10 using namespace std; 11 const int inf = 0x3f3f3f3f; 12 typedef long long ll; 13 const int N = (int)1e5 + 5; 14 15 vector<int> G[N]; 16 bool sex[N],vis[N]; 17 bool have; 18 19 void dfs(int u,int deep) 20 { 21 if(deep == 6) return; 22 if(vis[u]) {have = true;return;} 23 vis[u] = 1; 24 for(int i=0;i<G[u].size();i++) 25 { 26 dfs(G[u][i],deep+1); 27 } 28 } 29 30 int main() 31 { 32 int n,k; 33 scanf("%d",&n); 34 for(int i=1;i<=n;i++) 35 { 36 char s1[10],s2[10],s3[10],s4[10]; 37 scanf("%s%s%s%s",s1,s2,s3,s4); 38 if(atoi(s3) != -1) G[atoi(s1)].push_back(atoi(s3)),sex[atoi(s3)]=1; 39 if(atoi(s4) != -1) G[atoi(s1)].push_back(atoi(s4)),sex[atoi(s4)]=0; 40 sex[atoi(s1)] = s2[0]=='M'; 41 } 42 43 scanf("%d",&k); 44 for(int i=1;i<=k;i++) 45 { 46 char s1[10],s2[10]; 47 scanf("%s%s",s1,s2); 48 int x = atoi(s1),y = atoi(s2); 49 50 have = false; 51 memset(vis,0,sizeof(vis)); 52 dfs(x,1); 53 dfs(y,1); 54 if(sex[x] == sex[y]) puts("Never Mind"); 55 else if(have) puts("No"); 56 else puts("Yes"); 57 } 58 } View Code

?

  直搗黃龍。這題是最短路的一個變種。可以使用當時省賽那題的方法,不過有一組數據WA了,,也不知道為什么- -。然后我用dfs亂搞,結果AC了。這題也算是最短路的一個好題了吧。具體見代碼(上面的一份是WA了一組的,下面的是AC的):

1 #include <stdio.h> 2 #include <algorithm> 3 #include <string.h> 4 #include <vector> 5 #include <map> 6 #include <set> 7 #include <queue> 8 #include <iostream> 9 #include <stdlib.h> 10 #include <string> 11 #include <stack> 12 using namespace std; 13 const int inf = 0x3f3f3f3f; 14 typedef long long ll; 15 typedef pair<int,int> pii; 16 const int N = 200 + 5; 17 18 struct edge 19 { 20 int v,w; 21 int kill; 22 }; 23 vector<edge> G[N]; 24 edge pre[N]; 25 vector<edge> p[N]; 26 int d[N],cnt[N],d2[N],d3[N]; 27 map<string,int> M; 28 map<int,string> M2; 29 30 void dij() 31 { 32 memset(d,inf,sizeof(d)); 33 memset(d2,0,sizeof(d2)); 34 memset(d3,0,sizeof(d3)); 35 d[1] = 0; 36 d2[1] = 0; 37 d3[1] = 0; 38 priority_queue<pii,vector<pii>,greater<pii> > Q; 39 Q.push(pii(0,1)); 40 while(!Q.empty()) 41 { 42 pii x = Q.top();Q.pop(); 43 int u = x.second; 44 int dis = x.first; 45 if(d[u] != dis) continue; 46 for(int i=0;i<G[u].size();i++) 47 { 48 edge e = G[u][i]; 49 if(d[e.v] >= d[u]+e.w) 50 { 51 if(d[e.v] > d[u]+e.w) 52 { 53 d[e.v] = d[u]+e.w; 54 d2[e.v] = d2[u]+1; 55 d3[e.v] = d3[u]+e.kill; 56 Q.push(pii(d[e.v],e.v)); 57 pre[e.v] = (edge){u}; 58 59 p[e.v].clear(); 60 p[e.v].push_back((edge){u}); 61 } 62 else 63 { 64 p[e.v].push_back((edge){u}); 65 66 if(d2[e.v] <= d2[u]+1) 67 { 68 if(d2[e.v] < d2[u]+1) 69 { 70 d[e.v] = d[u]+e.w; 71 d2[e.v] = d2[u]+1; 72 d3[e.v] = d3[u]+e.kill; 73 Q.push(pii(d[e.v],e.v)); 74 pre[e.v] = (edge){u}; 75 } 76 else 77 { 78 if(d3[e.v] <= d3[u]+e.kill) 79 { 80 if(d3[e.v] < d3[u]+e.kill) 81 { 82 d[e.v] = d[u]+e.w; 83 d2[e.v] = d2[u]+1; 84 d3[e.v] = d3[u]+e.kill; 85 Q.push(pii(d[e.v],e.v)); 86 pre[e.v] = (edge){u}; 87 } 88 } 89 } 90 } 91 } 92 } 93 } 94 } 95 } 96 97 int Cnt=0; 98 void dfs(int u) 99 { 100 if(u==1) {Cnt++;return;} 101 for(int i=0;i<p[u].size();i++) 102 { 103 edge e = p[u][i]; 104 dfs(e.v); 105 } 106 } 107 108 int main() 109 { 110 int n,k,tot=0; 111 scanf("%d%d",&n,&k); 112 string st,ed; 113 cin >> st >> ed; 114 M[st] = 1; 115 M2[1] = st; 116 cnt[1] = 0; 117 for(int i=2;i<=n;i++) 118 { 119 string s; 120 cin >> s >> cnt[i]; 121 M[s] = i; 122 M2[i] = s; 123 } 124 scanf("%d",&k); 125 while(k--) 126 { 127 string u,v; 128 int w; 129 cin >> u >> v >> w; 130 G[M[u]].push_back((edge){M[v],w,cnt[M[v]]}); 131 G[M[v]].push_back((edge){M[u],w,cnt[M[u]]}); 132 } 133 134 dij(); 135 dfs(M[ed]); 136 137 vector<string> ans; 138 int now = M[ed]; 139 while(now != 1) 140 { 141 ans.push_back(M2[now]); 142 now = pre[now].v; 143 } 144 ans.push_back(st); 145 146 for(int i=ans.size()-1;i>=0;i--) 147 { 148 if(i!=ans.size()-1) printf("->"); 149 cout << ans[i]; 150 } 151 puts(""); 152 printf("%d %d %d\n",Cnt,d[M[ed]],d3[M[ed]]); 153 } View Code 1 #include <stdio.h> 2 #include <algorithm> 3 #include <string.h> 4 #include <vector> 5 #include <map> 6 #include <set> 7 #include <queue> 8 #include <iostream> 9 #include <stdlib.h> 10 #include <string> 11 #include <stack> 12 using namespace std; 13 const int inf = 0x3f3f3f3f; 14 typedef long long ll; 15 typedef pair<int,int> pii; 16 const int N = 200 + 5; 17 18 struct edge 19 { 20 int v,w; 21 }; 22 struct way 23 { 24 int p_cnt,kill; 25 bool operator < (const way& A)const 26 { 27 return p_cnt==A.p_cnt?kill>A.kill:p_cnt>A.p_cnt; 28 } 29 }; 30 vector<edge> G[N]; 31 vector<edge> p[N]; 32 vector<way> W; 33 int d[N],cnt[N]; 34 map<string,int> M; 35 map<int,string> M2; 36 37 void dij() 38 { 39 memset(d,inf,sizeof(d)); 40 d[1] = 0; 41 priority_queue<pii,vector<pii>,greater<pii> > Q; 42 Q.push(pii(0,1)); 43 while(!Q.empty()) 44 { 45 pii x = Q.top();Q.pop(); 46 int u = x.second; 47 int dis = x.first; 48 if(d[u] != dis) continue; 49 for(int i=0;i<G[u].size();i++) 50 { 51 edge e = G[u][i]; 52 if(d[e.v] >= d[u]+e.w) 53 { 54 if(d[e.v] > d[u]+e.w) 55 { 56 d[e.v] = d[u]+e.w; 57 Q.push(pii(d[e.v],e.v)); 58 p[e.v].clear(); 59 p[e.v].push_back((edge){u,e.w}); 60 } 61 else p[e.v].push_back((edge){u,e.w}); 62 } 63 } 64 } 65 } 66 67 int Cnt=0; 68 void dfs(int u,int p_cnt,int kill) 69 { 70 if(u==1) {Cnt++;W.push_back((way){p_cnt,kill});return;} 71 for(int i=0;i<p[u].size();i++) 72 { 73 edge e = p[u][i]; 74 dfs(e.v,p_cnt+1,kill+cnt[e.v]); 75 } 76 } 77 78 int A,B; 79 vector<string> ans; 80 void findAns(int u,int p_cnt,int kill) 81 { 82 if(u==1) 83 { 84 if(A==p_cnt && B==kill) 85 { 86 for(int i=ans.size()-1;i>=0;i--) 87 { 88 if(i!=ans.size()-1) printf("->"); 89 cout<<ans[i]; 90 } 91 puts(""); 92 93 return; 94 } 95 else return; 96 } 97 for(int i=0;i<p[u].size();i++) 98 { 99 edge e = p[u][i]; 100 ans.push_back(M2[e.v]); 101 findAns(e.v,p_cnt+1,kill+cnt[e.v]); 102 ans.erase(ans.end()); 103 } 104 } 105 106 int main() 107 { 108 int n,k,tot=0; 109 scanf("%d%d",&n,&k); 110 string st,ed; 111 cin >> st >> ed; 112 M[st] = 1; 113 M2[1] = st; 114 cnt[1] = 0; 115 for(int i=2;i<=n;i++) 116 { 117 string s; 118 cin >> s >> cnt[i]; 119 M[s] = i; 120 M2[i] = s; 121 } 122 scanf("%d",&k); 123 while(k--) 124 { 125 string u,v; 126 int w; 127 cin >> u >> v >> w; 128 G[M[u]].push_back((edge){M[v],w}); 129 G[M[v]].push_back((edge){M[u],w}); 130 } 131 132 dij(); 133 134 dfs(M[ed],0,cnt[M[ed]]); 135 sort(W.begin(),W.end()); 136 137 A=W[0].p_cnt,B=W[0].kill; 138 ans.push_back(ed); 139 findAns(M[ed],0,cnt[M[ed]]); 140 141 printf("%d %d %d\n",Cnt,d[M[ed]],W[0].kill); 142 } View Code

值得注意的是,在寫完以后我發現用來記錄最短路邊的pre數組,只需要記錄來時候的點就夠了。

————————————偉大的分界線——————————————

  這里是第二天的時候補充的,因為找到上面的第一份代碼為何錯了。

  原因在于用于記錄某點的各種最短路中到達這個點的點(即p數組記錄的點)有重復,導致最短路徑的誤判。

  舉個例子如下:

  用第一種方法的話,因為即使dis相同,點也要入優先隊列,那么以上圖為例,D就被入隊了兩次。從而E的p數組中儲存了兩個D,這樣在使用p數組進行反向dfs的時候,路徑數就會出錯了。

  解決方法的話有兩個。第一,p數組的含義是可以完成最短路中的到達這個點的不同的點,那么用set來儲存p數組即可。代碼如下:

1 #include <stdio.h> 2 #include <algorithm> 3 #include <string.h> 4 #include <vector> 5 #include <map> 6 #include <set> 7 #include <queue> 8 #include <iostream> 9 #include <stdlib.h> 10 #include <string> 11 #include <stack> 12 using namespace std; 13 const int inf = 0x3f3f3f3f; 14 typedef long long ll; 15 typedef pair<int,int> pii; 16 const int N = 200 + 5; 17 18 struct edge 19 { 20 int v,w; 21 int kill; 22 }; 23 vector<edge> G[N]; 24 edge pre[N]; 25 set<int> p[N]; 26 int d[N],cnt[N],d2[N],d3[N]; 27 map<string,int> M; 28 map<int,string> M2; 29 30 void dij() 31 { 32 memset(d,inf,sizeof(d)); 33 memset(d2,0,sizeof(d2)); 34 memset(d3,0,sizeof(d3)); 35 d[1] = 0; 36 d2[1] = 0; 37 d3[1] = 0; 38 priority_queue<pii,vector<pii>,greater<pii> > Q; 39 Q.push(pii(0,1)); 40 while(!Q.empty()) 41 { 42 pii x = Q.top();Q.pop(); 43 int u = x.second; 44 int dis = x.first; 45 if(d[u] != dis) continue; 46 for(int i=0;i<G[u].size();i++) 47 { 48 edge e = G[u][i]; 49 if(d[e.v] >= d[u]+e.w) 50 { 51 if(d[e.v] > d[u]+e.w) 52 { 53 d[e.v] = d[u]+e.w; 54 d2[e.v] = d2[u]+1; 55 d3[e.v] = d3[u]+e.kill; 56 Q.push(pii(d[e.v],e.v)); 57 pre[e.v] = (edge){u}; 58 59 p[e.v].clear(); 60 p[e.v].insert(u); 61 } 62 else 63 { 64 p[e.v].insert(u); 65 66 if(d2[e.v] <= d2[u]+1) 67 { 68 if(d2[e.v] < d2[u]+1) 69 { 70 d[e.v] = d[u]+e.w; 71 d2[e.v] = d2[u]+1; 72 d3[e.v] = d3[u]+e.kill; 73 Q.push(pii(d[e.v],e.v)); 74 pre[e.v] = (edge){u}; 75 } 76 else 77 { 78 if(d3[e.v] <= d3[u]+e.kill) 79 { 80 if(d3[e.v] < d3[u]+e.kill) 81 { 82 d[e.v] = d[u]+e.w; 83 d2[e.v] = d2[u]+1; 84 d3[e.v] = d3[u]+e.kill; 85 Q.push(pii(d[e.v],e.v)); 86 pre[e.v] = (edge){u}; 87 } 88 } 89 } 90 } 91 } 92 } 93 } 94 } 95 } 96 97 int Cnt=0; 98 bool vis[N]; 99 void dfs(int u) 100 { 101 if(u==1) {Cnt++;return;} 102 for(set<int>::iterator it=p[u].begin();it!=p[u].end();it++) 103 { 104 int v = *it; 105 dfs(v); 106 } 107 } 108 109 int main() 110 { 111 int n,k,tot=0; 112 scanf("%d%d",&n,&k); 113 string st,ed; 114 cin >> st >> ed; 115 M[st] = 1; 116 M2[1] = st; 117 cnt[1] = 0; 118 for(int i=2;i<=n;i++) 119 { 120 string s; 121 cin >> s >> cnt[i]; 122 M[s] = i; 123 M2[i] = s; 124 } 125 scanf("%d",&k); 126 while(k--) 127 { 128 string u,v; 129 int w; 130 cin >> u >> v >> w; 131 G[M[u]].push_back((edge){M[v],w,cnt[M[v]]}); 132 G[M[v]].push_back((edge){M[u],w,cnt[M[u]]}); 133 } 134 135 dij(); 136 memset(vis,0,sizeof(vis)); 137 dfs(M[ed]); 138 139 vector<string> ans; 140 int now = M[ed]; 141 while(now != 1) 142 { 143 ans.push_back(M2[now]); 144 now = pre[now].v; 145 } 146 ans.push_back(st); 147 148 for(int i=ans.size()-1;i>=0;i--) 149 { 150 if(i!=ans.size()-1) printf("->"); 151 cout << ans[i]; 152 } 153 puts(""); 154 printf("%d %d %d\n",Cnt,d[M[ed]],d3[M[ed]]); 155 } View Code

第二,可以使用從頭開始dfs的方法,直接在圖G上搜索路徑,當到達終點且路徑是最短路時,Cnt才加1(似乎這種方法看起來更好)。具體見代碼(這樣的話p數組也不需要了,只需要pre數組即可):

1 #include <stdio.h> 2 #include <algorithm> 3 #include <string.h> 4 #include <vector> 5 #include <map> 6 #include <set> 7 #include <queue> 8 #include <iostream> 9 #include <stdlib.h> 10 #include <string> 11 #include <stack> 12 using namespace std; 13 const int inf = 0x3f3f3f3f; 14 typedef long long ll; 15 typedef pair<int,int> pii; 16 const int N = 200 + 5; 17 18 struct edge 19 { 20 int v,w; 21 int kill; 22 }; 23 vector<edge> G[N]; 24 edge pre[N]; 25 vector<edge> p[N]; 26 int d[N],cnt[N],d2[N],d3[N]; 27 map<string,int> M; 28 map<int,string> M2; 29 string st,ed; 30 31 void dij() 32 { 33 memset(d,inf,sizeof(d)); 34 memset(d2,0,sizeof(d2)); 35 memset(d3,0,sizeof(d3)); 36 d[1] = 0; 37 d2[1] = 0; 38 d3[1] = 0; 39 priority_queue<pii,vector<pii>,greater<pii> > Q; 40 Q.push(pii(0,1)); 41 while(!Q.empty()) 42 { 43 pii x = Q.top();Q.pop(); 44 int u = x.second; 45 int dis = x.first; 46 if(d[u] != dis) continue; 47 for(int i=0;i<G[u].size();i++) 48 { 49 edge e = G[u][i]; 50 if(d[e.v] >= d[u]+e.w) 51 { 52 if(d[e.v] > d[u]+e.w) 53 { 54 d[e.v] = d[u]+e.w; 55 d2[e.v] = d2[u]+1; 56 d3[e.v] = d3[u]+e.kill; 57 Q.push(pii(d[e.v],e.v)); 58 pre[e.v] = (edge){u}; 59 60 p[e.v].clear(); 61 p[e.v].push_back((edge){u}); 62 } 63 else 64 { 65 p[e.v].push_back((edge){u}); 66 67 if(d2[e.v] <= d2[u]+1) 68 { 69 if(d2[e.v] < d2[u]+1) 70 { 71 d[e.v] = d[u]+e.w; 72 d2[e.v] = d2[u]+1; 73 d3[e.v] = d3[u]+e.kill; 74 Q.push(pii(d[e.v],e.v)); 75 pre[e.v] = (edge){u}; 76 } 77 else 78 { 79 if(d3[e.v] <= d3[u]+e.kill) 80 { 81 if(d3[e.v] < d3[u]+e.kill) 82 { 83 d[e.v] = d[u]+e.w; 84 d2[e.v] = d2[u]+1; 85 d3[e.v] = d3[u]+e.kill; 86 Q.push(pii(d[e.v],e.v)); 87 pre[e.v] = (edge){u}; 88 } 89 } 90 } 91 } 92 } 93 } 94 } 95 } 96 } 97 98 int Cnt=0; 99 bool vis[N]; 100 void dfs(int u,int dis) 101 { 102 if(u==M[ed] && dis==d[M[ed]]) {Cnt++;return;} 103 for(int i=0;i<G[u].size();i++) 104 { 105 edge e = G[u][i]; 106 if(!vis[e.v]) 107 { 108 vis[e.v]=1; 109 dfs(e.v,dis+e.w); 110 vis[e.v]=0; 111 } 112 } 113 } 114 115 int main() 116 { 117 int n,k,tot=0; 118 scanf("%d%d",&n,&k); 119 cin >> st >> ed; 120 M[st] = 1; 121 M2[1] = st; 122 cnt[1] = 0; 123 for(int i=2;i<=n;i++) 124 { 125 string s; 126 cin >> s >> cnt[i]; 127 M[s] = i; 128 M2[i] = s; 129 } 130 scanf("%d",&k); 131 while(k--) 132 { 133 string u,v; 134 int w; 135 cin >> u >> v >> w; 136 G[M[u]].push_back((edge){M[v],w,cnt[M[v]]}); 137 G[M[v]].push_back((edge){M[u],w,cnt[M[u]]}); 138 } 139 140 dij(); 141 memset(vis,0,sizeof(vis)); 142 dfs(1,0); 143 144 vector<string> ans; 145 int now = M[ed]; 146 while(now != 1) 147 { 148 ans.push_back(M2[now]); 149 now = pre[now].v; 150 } 151 ans.push_back(st); 152 153 for(int i=ans.size()-1;i>=0;i--) 154 { 155 if(i!=ans.size()-1) printf("->"); 156 cout << ans[i]; 157 } 158 puts(""); 159 printf("%d %d %d\n",Cnt,d[M[ed]],d3[M[ed]]); 160 } View Code

  現在想想,原來我的dfs亂搞法也只是弄巧成拙才AC的啊= =。

  下面是上面那個圖的數據:

1 7 8 A G 2 B 10 3 C 15 4 D 20 5 E 30 6 F 25 7 G 50 8 A B 10 9 B D 15 10 A C 15 11 C D 10 12 D E 20 13 E G 30 14 D F 30 15 F G 20 偉大的數據

?

轉載于:https://www.cnblogs.com/zzyDS/p/5678129.html

總結

以上是生活随笔為你收集整理的2016团体程序设计天梯赛-决赛-部分题解的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。

欧美一级日韩免费不卡 | 黄色国产在线观看 | 亚洲 成人 欧美 | 久久久久久久网 | 亚洲精品国产精品乱码在线观看 | 国产精品久久片 | 操综合 | 国产成在线观看免费视频 | 最近日本mv字幕免费观看 | 国产99在线播放 | 国产精品99精品久久免费 | 国内精品在线看 | 91亚洲精品久久久 | 日韩久久精品一区二区 | mm1313亚洲精品国产 | 日韩免费视频 | 久久99久久99精品免观看粉嫩 | 天天干天天天天 | 免费在线观看黄色网 | 少妇搡bbbb搡bbb搡69 | 一区二区三区在线看 | 亚洲精品视频在线观看视频 | 91精品视频观看 | 91色蜜桃| 99久久精品久久亚洲精品 | 久操久 | 国产精品中文字幕在线播放 | 色无五月 | 天堂av在线免费 | 久章草在线观看 | 最新超碰在线 | 91精品在线免费 | 一区二区三区 中文字幕 | 中文字幕一区二区三区在线播放 | 久久久久福利视频 | 探花视频在线观看免费 | 国产1区2| 日韩视频中文字幕在线观看 | 欧美大片mv免费 | 国产精品久久久久久久久免费看 | 亚洲区色 | 成人久久久久久久久 | 国产精品美女在线观看 | 天天色播 | 在线性视频日韩欧美 | 国产一区在线播放 | 黄污视频网站 | 日韩欧美视频二区 | 久久理论电影网 | 免费观看丰满少妇做爰 | 天天操夜夜做 | 久草热久草视频 | 91成人免费视频 | 国产福利网站 | 夜夜嗨av色一区二区不卡 | 91精品蜜桃 | 日韩一区二区免费视频 | 日韩区欠美精品av视频 | 欧美日韩一区二区免费在线观看 | 国产人成一区二区三区影院 | 99视频精品免费观看, | 国产综合精品久久 | 亚洲91中文字幕无线码三区 | 亚洲三级精品 | 国产精品系列在线观看 | 999视频精品 | 日韩免费观看av | 国产精品一区二区av日韩在线 | 亚洲精品乱码久久久久 | 在线观看亚洲免费视频 | 久久久久久久久久久久电影 | 五月天av在线 | 最近免费中文字幕mv在线视频3 | 九九综合九九综合 | 天天翘av | 99久久久久久久久久 | 福利区在线观看 | 波多野结衣小视频 | 在线免费观看羞羞视频 | 精品国产亚洲一区二区麻豆 | 亚洲精品视频在线免费 | 日韩欧美v| 久久综合五月婷婷 | 人人澡人人干 | 91亚洲精品在线观看 | 丝袜美女视频网站 | 亚洲国产成人在线播放 | 午夜丁香网 | 91av电影在线观看 | av免费线看| 日韩av快播电影网 | 久久深爱网 | 天天插狠狠插 | 色黄www小说 | 国产小视频在线观看 | 免费欧美精品 | 婷香五月| 日韩欧美亚州 | 国产专区精品视频 | 免费欧美 | 中文字幕123区 | 国产精品免费在线 | 成人小视频免费在线观看 | 在线看片a| 天天爽天天爽夜夜爽 | 国产精品永久免费在线 | 成人性生活大片 | 国产一级片不卡 | 日本高清xxxx | 日韩免费在线观看网站 | 99久久精品久久久久久清纯 | 91在线精品播放 | 国产小视频在线免费观看视频 | 日韩一区二区三区免费视频 | 国产高清亚洲 | 亚洲综合在线视频 | 久久tv | 亚洲资源网 | 国产黄免费在线观看 | 亚洲va欧美va人人爽 | 91精品久久久久久综合乱菊 | 久久久精品网 | 亚洲最新av网站 | 久久人人97超碰国产公开结果 | 国产黄影院色大全免费 | 中日韩男男gay无套 日韩精品一区二区三区高清免费 | 97人人添人澡人人爽超碰动图 | 碰超人人 | 婷婷深爱| 国产精品密入口果冻 | www.天天射.com| 久久久久久免费视频 | 免费观看全黄做爰大片国产 | 免费视频a | 又色又爽的网站 | 在线免费91 | 综合成人在线 | 中文字幕888 | 久久精品成人欧美大片古装 | 亚洲视频,欧洲视频 | 久久亚洲综合国产精品99麻豆的功能介绍 | 欧美超碰在线 | 在线免费观看黄色av | 久久久噜噜噜久久久 | 免费网站黄 | 一区二区三区手机在线观看 | 日本少妇高清做爰视频 | 国产亚洲亚洲 | 精品日韩在线 | 久久不射影院 | 亚洲欧美日韩国产精品一区午夜 | 超碰人人在 | 欧美网址在线观看 | 不卡的av电影在线观看 | 91探花在线 | 夜夜操狠狠干 | 国产高清精| 97成人超碰 | 国产a国产 | 日韩网站在线播放 | 天天激情天天干 | 成年人免费在线播放 | 久久一区二区三区日韩 | 97品白浆高清久久久久久 | 国产在线观看二区 | 日韩在线精品一区 | 久草视频在线新免费 | 国产999精品 | 成人av电影免费在线播放 | 婷婷5月激情5月 | 色多多污污在线观看 | 五月婷婷视频在线观看 | 国产特级毛片aaaaaa | 色狠狠综合 | 国产成人一区二区三区免费看 | 一区二区av| 午夜在线免费观看视频 | 久久久久福利视频 | 丁香在线视频 | 日本精品久久久一区二区三区 | 欧美日韩高清一区 | 国产精品v欧美精品v日韩 | 99超碰在线播放 | 五月天伊人 | 欧美最猛性xxxxx免费 | 久久成| 国产精品第2页 | 521色香蕉网站在线观看 | 亚洲国产精品500在线观看 | 国产特级毛片aaaaaa高清 | 国产精品18久久久久久久 | 成人性生交大片免费看中文网站 | 亚洲在线 | 五月天.com | 欧美国产日韩一区二区三区 | 综合在线色 | 国产又粗又猛又色又黄网站 | 美女视频永久黄网站免费观看国产 | 国产黄色看片 | 国产亚洲人 | 美女中文字幕 | 操久| 99久久成人| 狠狠色丁香 | 精品一区二区免费在线观看 | 丝袜网站在线观看 | 最近免费中文字幕 | 免费看的黄色录像 | 中文字幕在线看 | av在线播放快速免费阴 | 中文字幕久久精品亚洲乱码 | 热久在线| 精品视频在线播放 | 国产高清专区 | 天天射天天射 | 精品免费国产一区二区三区四区 | 天天天天天天天天操 | 久久久不卡影院 | 国产一级精品视频 | 日韩免费不卡视频 | 国产午夜精品久久 | www免费看片com | 国内99视频 | 日韩精品中文字幕一区二区 | 91免费在线看片 | 在线视频你懂 | 亚洲国产精品传媒在线观看 | 久久久成人精品 | 欧美成人aa | 国产精品一区二区免费视频 | 成年人国产精品 | 97超碰人人模人人人爽人人爱 | av不卡在线看 | 亚洲一区二区精品 | 欧美日韩国产二区三区 | 天天射色综合 | 中文字幕色婷婷在线视频 | 久章草在线 | 狠狠操狠狠干天天操 | 国产精品1区2区 | 久草免费看 | 黄色片网站大全 | 人人爽人人爽人人爽学生一级 | 四虎在线免费视频 | 亚洲精品视频网站在线观看 | 99超碰在线观看 | 91麻豆精品国产自产在线游戏 | 99精品视频观看 | 久久av一区二区三区亚洲 | 欧美日韩中文视频 | 亚洲视频在线免费看 | 一级做a爱片性色毛片www | 国产欧美精品一区二区三区 | 久久99国产综合精品 | 不卡的av在线 | 黄色大片视频网站 | 国产精品一区二区三区观看 | 黄污网 | 国产又粗又猛又爽又黄的视频先 | 97视频免费在线 | 在线免费观看视频一区 | 二区三区中文字幕 | 久久日韩精品 | 九九在线免费视频 | 亚洲成人精品久久久 | 久久99国产精品免费网站 | av一级久久 | 欧美a在线看 | 欧美日韩高清国产 | 国产精品美女久久久免费 | 91高清免费观看 | 国产日韩视频在线观看 | 美女福利视频一区二区 | av五月婷婷 | 久久精品视频在线播放 | 国产精品毛片一区 | 美女久久 | 久草com| 2019中文字幕第一页 | 特级西西www44高清大胆图片 | 丁香婷婷激情国产高清秒播 | 国产资源在线观看 | 在线观看免费一级片 | 天天天干天天射天天天操 | 日韩中文三级 | 亚洲日本一区二区在线 | 狠狠的干 | 日韩免费一区二区三区 | 超碰在线人人草 | 青春草免费视频 | 国产精品1区2区3区在线观看 | 午夜视频色 | 精品国产伦一区二区三区观看体验 | 欧美一区二区在线刺激视频 | 午夜美女福利 | 五月天激情综合网 | 91麻豆网 | 欧美在线视频一区二区三区 | 成人黄色av免费在线观看 | 日韩欧美在线高清 | 日韩av视屏在线观看 | 91大神dom调教在线观看 | 久久影视网 | 久久久96 | 五月婷婷影院 | 天天操天天怕 | 97免费视频在线 | 国产一区二区三区免费在线观看 | 日日夜夜网 | 国产精品岛国久久久久久久久红粉 | 少妇bbbb搡bbbb桶 | 久久毛片网站 | 日韩一区二区三 | 中文字幕资源在线观看 | 免费成人在线电影 | 超碰公开97| 亚洲综合导航 | 天天综合天天综合 | 欧美日韩精品在线观看 | 亚洲精品视频一 | av免费电影在线 | 国产一级性生活视频 | 免费的国产精品 | 色综合久久久久综合99 | 久久久久国产一区二区 | 国语自产偷拍精品视频偷 | 国产亚洲精品成人av久久影院 | 永久av免费在线观看 | 精品久久久久久久久久久久久久久久 | 视频精品一区二区三区 | 国产毛片久久久 | 久久99久久99久久 | 欧美日韩高清在线观看 | 国产一级高清 | 一区二区中文字幕在线 | 国产美女视频免费观看的网站 | 日韩色综合 | 久久综合网色—综合色88 | 色姑娘综合 | 91精品一区二区三区久久久久久 | 超碰在线亚洲 | 久久久久久久久久久网 | 日韩簧片在线观看 | 激情网站免费观看 | 天天干天天搞天天射 | 久久人人爽人人人人片 | www.超碰 | 国产精品丝袜在线 | 人人澡人人草 | 免费精品人在线二线三线 | 国产成人精品av | 激情网综合 | av电影免费在线播放 | 五月婷婷另类国产 | 97超碰国产精品女人人人爽 | 国产精品麻豆99久久久久久 | 99热手机在线观看 | 日韩丝袜在线观看 | 日日日视频 | 欧美日韩精品电影 | 国产一级片不卡 | 99精品国产福利在线观看免费 | 97av视频| 欧美狠狠色 | 久久久久99精品成人片三人毛片 | 日本不卡一区二区三区在线观看 | 99在线免费观看视频 | 99在线热播精品免费 | 在线亚洲高清视频 | 日韩成人精品 | 日韩在线在线 | 国产精品毛片一区视频 | 91成人在线网站 | 天天曰天天 | 人人爽人人爽人人片av免 | 午夜婷婷在线观看 | 国产精品久久久久永久免费看 | 狠狠干狠狠插 | 丁香婷婷久久 | 久久伦理| 国色天香在线 | 免费色黄 | 黄色免费在线视频 | a黄色一级片 | av在线电影播放 | 91亚洲激情 | 香蕉视频网站在线观看 | 4438全国亚洲精品观看视频 | 久久久久97国产 | 日韩欧美一区二区在线播放 | 中文字幕字幕中文 | 亚洲永久av | 国产午夜三级一二三区 | 免费观看一级特黄欧美大片 | 一区二区中文字幕在线 | 国产精品 视频 | 日本中文字幕在线免费观看 | 婷婷丁香激情网 | 五月开心激情 | 97网在线观看 | 国产麻豆精品久久一二三 | 日韩精品一区二区三区三炮视频 | 在线国产高清 | 麻豆国产露脸在线观看 | 中文字幕亚洲不卡 | 久福利| 亚洲精品视频一 | 婷婷视频导航 | 91精品国产九九九久久久亚洲 | 黄色福利网 | 欧美久久久久久久 | 狠狠躁夜夜躁人人爽超碰97香蕉 | 97理论电影 | 久久在线精品 | 综合色综合色 | 黄色特一级片 | 69精品久久 | 中文字幕在线观 | 精品久久久久国产免费第一页 | 久久精品国产一区二区三区 | 91人人澡人人爽人人精品 | 91精品蜜桃 | 97精品欧美91久久久久久 | 午夜精品一区二区三区可下载 | 麻豆系列在线观看 | 国产精品久久视频 | 成 人 黄 色 视频免费播放 | av成人在线网站 | 色综合久久久久久久久五月 | 国产成人一区二区精品非洲 | 婷婷五月色综合 | 91尤物国产尤物福利在线播放 | 麻豆精品视频在线 | 中文字幕乱在线伦视频中文字幕乱码在线 | 91大神免费在线观看 | 亚洲在线视频网站 | 在线视频你懂得 | 色中色资源站 | 久久精品中文视频 | www四虎影院 | 在线精品视频免费播放 | 亚洲欧美视频在线播放 | 中文字幕一区二区三区精华液 | 亚洲欧洲日韩 | 国产一级做a爱片久久毛片a | 在线精品视频免费播放 | 男女视频国产 | 97在线免费视频 | 久久在线视频在线 | 国产小视频你懂的 | 久久人人爽人人爽人人片av软件 | 国精产品永久999 | 激情av在线播放 | 久久久亚洲麻豆日韩精品一区三区 | 黄在线 | 天天操天天能 | 精品嫩模福利一区二区蜜臀 | 91成年人在线观看 | 欧美疯狂性受xxxxx另类 | 色综合久久综合中文综合网 | 在线看片一区 | 国产精品乱码久久久久 | 在线观看日韩中文字幕 | 日韩免费小视频 | 国产麻豆果冻传媒在线观看 | 黄色特一级片 | 青青久草在线视频 | 亚洲国产成人久久综合 | 国产一区二区不卡视频 | 玖玖精品在线 | 园产精品久久久久久久7电影 | 免费看成人av | 欧美有色 | 免费高清在线观看电视网站 | 亚洲国产精品va在线看黑人 | 日韩精品五月天 | 射久久| 人人添人人澡人人澡人人人爽 | 9999国产| 欧美日韩伦理在线 | 一区二区三区四区五区在线 | 久久好看| 四虎成人免费观看 | 夜夜操夜夜干 | 超碰在线观看av | 日本免费久久高清视频 | 丁香久久 | 日韩欧美在线视频一区二区三区 | 天天摸日日摸人人看 | 西西www4444大胆在线 | 黄色小说网站在线 | 欧美一区在线观看视频 | 奇米导航| 激情视频在线高清看 | 日韩激情免费视频 | 91九色网站 | 国产成人在线免费观看 | 欧美极品少妇xxxx | 亚洲精品一区二区精华 | 国产精品日韩在线观看 | 婷婷五综合| 嫩模bbw搡bbbb搡bbbb | 精品九九久久 | 99国产精品免费网站 | 91人人射 | 久久国产精品久久国产精品 | 免费看黄的视频 | 国产成人福利片 | 高清视频一区二区三区 | 日韩精品一区二区三区电影 | 国产在线91在线电影 | 美女网站色免费 | 亚洲更新最快 | 日本在线中文 | 五月天久久久 | 久久精品伊人 | 久久er99热精品一区二区三区 | 正在播放亚洲精品 | 成人黄色免费在线观看 | 精品在线一区二区三区 | 天天操夜夜逼 | 精品国产乱码久久久久久1区二区 | 天天干人人插 | 国产精品美乳一区二区免费 | 国产一区二区三区网站 | 天天亚洲| 国产成人精品一区二区三区在线观看 | 最新日韩在线 | 最新av在线网址 | 在线视频观看国产 | 国产成人精品综合 | 免费观看mv大片高清 | 国内精品久久久久久久久久清纯 | av黄色免费看 | www.五月婷婷 | 在线观看播放av | 精品久久99 | 国产一卡久久电影永久 | 欧美日韩免费观看一区二区三区 | 日韩一级精品 | 久久精品久久99 | 91精品视频免费看 | 在线国产日本 | 996久久国产精品线观看 | 免费看黄在线观看 | 能在线观看的日韩av | 久久精品视频在线免费观看 | 99久视频 | 91最新在线| 麻豆精品视频在线 | 国产精品观看在线亚洲人成网 | 蜜臀av性久久久久蜜臀aⅴ四虎 | 极品美女被弄高潮视频网站 | 91看片看淫黄大片 | 精品五月天 | 国产精品欧美久久久久久 | 久久久久女人精品毛片九一 | 久久免费资源 | 国产精品亚洲片在线播放 | 2019中文字幕第一页 | 精品国产精品国产偷麻豆 | av色网站 | 欧美天堂视频在线 | 99视频+国产日韩欧美 | 欧美性生爱| 婷婷伊人网 | 国产护士hd高朝护士1 | 日日色综合 | 欧美另类xxx | 欧美xxxxx在线视频 | 日本韩国精品一区二区在线观看 | 日韩av电影免费在线观看 | 日本久久成人中文字幕电影 | 伊人中文在线 | 在线黄频| 成 人 黄 色 视频 免费观看 | 欧美精品一区二区三区四区在线 | 尤物一区二区三区 | 黄色一级影院 | 日韩在线观看 | 国产美女主播精品一区二区三区 | 亚洲成a人片77777潘金莲 | 国产成人精品一区一区一区 | 亚洲精品毛片一级91精品 | 91视频在线观看大全 | 久久久久激情 | 中文字幕色综合网 | 免费在线成人 | 精品国产诱惑 | 蜜臀91丨九色丨蝌蚪老版 | 中文字幕在线看视频国产中文版 | 香蕉视频网址 | 亚洲精品美女久久久 | 国产欧美精品一区二区三区四区 | 在线观看免费91 | 九九视频免费 | 久久艹久久 | 黄色片网站 | 超碰日韩在线 | 国内精品在线观看视频 | 香蕉视频在线播放 | 国产人成在线观看 | 五月开心六月伊人色婷婷 | 涩涩网站免费 | 色噜噜日韩精品欧美一区二区 | 国产精品男女啪啪 | 久久影院中文字幕 | 久久久久久久久久久久亚洲 | 欧美做受高潮电影o | 伊人婷婷久久 | 欧美久久久久久久久久久久 | 亚洲日本韩国一区二区 | 国产二区免费视频 | 亚洲一区美女视频在线观看免费 | 91在线小视频 | 高清在线观看av | 麻豆综合网 | 97精品国产97久久久久久 | 丝袜美腿一区 | 婷婷在线综合 | 美女啪啪图片 | 国产精品一区二区久久精品爱微奶 | 欧美福利视频一区 | 久草精品在线播放 | 奇米网777| 成人久久久久久久久久 | 99久热| 国产精品字幕 | 亚洲精品美女在线观看播放 | 久久一区二区三区四区 | www.91av在线| 精品视频在线播放 | 在线观看中文 | www国产精品com | 天堂av最新网址 | 九九国产精品视频 | 九九激情视频 | 午夜av剧场| 国产精品入口麻豆www | 中文字幕久久网 | 探花视频在线观看免费 | 日韩av电影国产 | 国产一区精品在线 | 99免费在线观看 | av电影在线观看 | 国产在线视频导航 | 久久久久99999 | 欧美日韩国产mv | 国产精品一区二区电影 | 91人人爽人人爽人人精88v | 成年人网站免费在线观看 | 久久99国产精品免费 | 在线观看v片 | 黄色a在线| 最近免费观看的电影完整版 | 精品夜夜嗨av一区二区三区 | 久久久久国产免费免费 | 91超碰在线播放 | 国产成人一区二区三区在线观看 | 欧美成人基地 | 国产成人亚洲在线观看 | 在线 国产一区 | 综合激情网 | 亚洲人视频在线 | 久久99精品国产麻豆宅宅 | 亚洲精品一区二区精华 | 国产色视频网站 | 77国产精品 | 999亚洲国产996395 | 免费看的黄色小视频 | 在线精品视频免费播放 | 99精品视频免费全部在线 | 天天插日日插 | 九九导航| 一区二区激情视频 | 久久精品这里热有精品 | 婷婷五天天在线视频 | 天天干天天搞天天射 | 中文字幕 影院 | 国产va饥渴难耐女保洁员在线观看 | 99爱精品视频 | 国产成人亚洲在线电影 | 91夫妻视频 | 亚洲精品乱码久久久久久蜜桃91 | 国产精品黄 | a久久久久久 | 在线av资源 | 国产高清av免费在线观看 | 日日夜日日干 | 成人免费视频在线观看 | 日韩a在线观看 | 久久这里有精品 | 在线观看成人一级片 | 天天综合网 天天 | av大片网址| 狠狠色噜噜狠狠狠狠 | 国内外激情视频 | 超碰97国产| 一级一片免费看 | 日日夜夜草 | 久久伦理 | 337p日本欧洲亚洲大胆裸体艺术 | 色av男人的天堂免费在线 | 激情久久五月 | 亚洲一区欧美精品 | 韩国在线视频一区 | 在线欧美国产 | 日本久久精品视频 | 婷婷色资源| 国产在线免费 | 亚洲电影自拍 | 日韩高清国产精品 | 免费观看www视频 | 久草资源在线 | 天天综合操| 国产视频69| 免费观看mv大片高清 | 夜夜躁日日躁狠狠躁 | a爱爱视频 | 中文字幕av一区二区三区四区 | 国产午夜三级一区二区三桃花影视 | 播五月婷婷| 欧美日韩精品区 | 黄色影院在线观看 | 97精品国产97久久久久久免费 | av九九九 | 婷婷九月激情 | 国产精品电影在线 | 五月婷婷丁香在线观看 | 96久久 | 欧洲激情在线 | 免费在线播放黄色 | 国产精品18videosex性欧美 | 久久视了 | 99视频免费在线观看 | 久久久精品欧美一区二区免费 | 伊人婷婷在线 | 日韩一二区在线观看 | 中文字幕丝袜一区二区 | 免费看的黄色录像 | 婷婷激情5月天 | 日韩三级在线 | 97国产情侣爱久久免费观看 | 久久伊人精品一区二区三区 | 国产精品不卡在线播放 | 国产精品女人久久久久久 | 不卡的av片| 日韩区在线观看 | 波多野结衣亚洲一区二区 | 精品一区二区在线免费观看 | 狠狠色免费 | 欧美久久久久久久久久久久久 | 91麻豆精品91久久久久同性 | 色婷婷六月天 | 久久色在线观看 | av在线免费在线观看 | 少妇18xxxx性xxxx片 | 亚洲精品视频免费看 | 91尤物在线播放 | 亚洲国产婷婷 | 黄色网在线免费观看 | 在线观看免费黄色 | 福利一区在线 | 在线看小早川怜子av | 国产视频观看 | 成人免费视频网站 | 狠狠色噜噜狠狠狠合久 | 国产精品黑丝在线观看 | 91看片在线 | 天天操夜夜拍 | 成人9ⅰ免费影视网站 | 91精品国产一区二区在线观看 | 在线观看中文字幕视频 | 91视频高清 | 日本精品一二区 | 精品国产精品久久 | 国产久草在线 | 久久国内精品 | 夜夜夜草| 黄色三级在线观看 | 日韩国产精品一区 | 天天射天天色天天干 | 青春草免费视频 | 色射色 | 国产午夜三级一二三区 | av电影免费在线 | 日本不卡一区二区 | 欧美一级淫片videoshd | 国产中文字幕视频在线观看 | 日日天天干 | 91免费高清| 国产精品久久久久久麻豆一区 | 五月色丁香 | 狠狠狠狠狠狠狠狠干 | 欧美日韩国产综合网 | 九九免费精品 | 欧美日韩视频在线播放 | 91精品在线麻豆 | 亚洲狠狠 | 一区二区三区四区在线 | 四虎最新入口 | 超碰在线98 | 一性一交视频 | 伊人黄| www久久| 免费日韩 精品中文字幕视频在线 | 天天干天天玩天天操 | 永久免费毛片 | 在线观看一区 | 日韩视频一区二区在线观看 | 99精品福利 | 国产小视频在线观看 | 永久免费的啪啪网站免费观看浪潮 | 国产在线国偷精品产拍免费yy | av中文字幕网址 | 日韩在线视频播放 | 精品在线免费观看 | 日韩高清免费观看 | 亚洲少妇久久 | 成人99免费视频 | 日韩精品一卡 | 91aaa在线观看 | 国产精品视频99 | 国产一区成人在线 | 色综合久久综合中文综合网 | 成人黄色资源 | 午夜婷婷在线观看 | 久久久久欠精品国产毛片国产毛生 | 久久综合色天天久久综合图片 | 日本中文在线观看 | 亚洲国产剧情 | 中文免费观看 | 99热在线国产 | 99人成在线观看视频 | 午夜免费福利视频 | 夜夜骑天天操 | 五月天精品视频 | 国产黑丝一区二区 | 欧美激情视频在线免费观看 | 国产97色| 成年人免费观看国产 | 中文字幕精品一区久久久久 | 日韩免费一区 | 色吊丝在线永久观看最新版本 | 日韩精品视频在线免费观看 | 久久亚洲欧美日韩精品专区 | 精品成人在线 | 黄网站色视频免费观看 | 免费在线看v | 特级aaa毛片 | 一级黄色片在线免费看 | 欧美性天天 | 久久久片 | 狠狠干天天操 | 在线播放 日韩专区 | 中文在线8资源库 | av久久久久久| 狠狠干电影| 最近中文字幕在线 | 911av视频| 天天干天天干天天干天天干天天干天天干 | 精品在线观看免费 | 亚洲精品乱码 | 91精品国产一区二区在线观看 | 手机成人免费视频 | 久久久91精品国产一区二区三区 | 国产一区二区在线免费 | 最新国产在线 | 久久精品久久久久久久 | 欧美日韩国产精品一区二区亚洲 | 午夜av在线电影 | 久久国产精品影片 | 91麻豆精品国产91久久久久久久久 | 国产成人精品三级 | 欧美激情精品久久久久久免费印度 | 国产黄视频在线观看 | 96精品高清视频在线观看软件特色 | 欧美精品久久久久久久亚洲调教 | 亚洲高清在线 | 精品一区二区三区在线播放 | 久久tv| 色99之美女主播在线视频 | 又黄又刺激的视频 | 日日爽夜夜操 | 97免费中文视频在线观看 | 亚洲欧洲成人精品av97 | 激情av资源网 | 91精品久久久久久 | 久久男人视频 | 婷婷五月在线视频 | 国产在线观看,日本 | 玖玖在线免费视频 | 久久久久久国产精品美女 | 欧美精品免费一区二区 | 日本色小说视频 | 日韩av手机在线观看 | 色婷久久 | 国产在线观看免费观看 | 视频三区在线 | 国产日韩欧美在线免费观看 | 丁香六月av | 亚洲乱码在线观看 | 亚洲黄色精品 | 91麻豆精品国产91久久久久 | 国产精品网站 | 欧美精品中文字幕亚洲专区 | 天天操天天操天天操天天操天天操天天操 | 久久久久亚洲精品 | 国产精品a成v人在线播放 | 天天干天天干天天色 | 又黄又刺激视频 | 日韩午夜电影 | 99国产精品久久久久老师 | 日本午夜免费福利视频 | 中文字幕文字幕一区二区 | 国产午夜三级一二三区 | 999在线精品 | 国产1区2区3区在线 亚洲自拍偷拍色图 | 美女在线免费观看视频 | 久久久黄色av | 91成人观看 | 成人中文字幕在线观看 | 91在线免费公开视频 | 亚洲久久视频 | 91麻豆精品国产91久久久久久 | 久久精品观看 | 国产精品99久久99久久久二8 | 999成人 | 欧美色噜噜噜 | 国产精品国产三级国产aⅴ入口 | 在线观看蜜桃视频 | 欧美一区中文字幕 | 亚洲精品视频免费 | 日韩高清在线观看 | 国产成人一区二区精品非洲 | 五月天婷亚洲天综合网鲁鲁鲁 | 麻豆视频国产精品 | 在线观看中文字幕av | 色综合久久久久久久 | 久久久久成人精品免费播放动漫 | 国产精品色视频 | 在线观看一区二区精品 | 亚洲毛片在线观看. | 韩国一区二区三区视频 | 国产麻豆精品免费视频 | 亚洲精品在线二区 | 免费h视频 | 国产精品福利午夜在线观看 | 97在线观 | 成人精品在线 | av一区二区三区在线观看 | 在线观看国产高清视频 | 四虎成人在线 | 美女精品久久 | 成在人线av | 亚洲经典视频在线观看 | 91久久偷偷做嫩草影院 | 男女精品久久 | 欧美精品一区二区蜜臀亚洲 | 91久久奴性调教 | 69人人| 日本黄色大片免费 | 国产色妞影院wwwxxx | 国产成人三级在线 | 国产成在线观看免费视频 | 免费看黄网站在线 | 美女福利视频在线 | 日韩在观看线 | 中文字幕在线视频一区二区 | 91香蕉视频在线 | 99视频国产在线 | 欧美精品在线观看一区 | av在线免费不卡 | 成人四虎| 亚洲欧洲精品一区二区精品久久久 | www.成人精品 | 国产精品中文 | 99热精品免费观看 | 成人sm另类专区 | 免费黄a大片 | 国产91免费观看 | 欧美日韩在线视频观看 | 97热久久免费频精品99 | 亚洲成人中文在线 | 国产精品自在线 | 美女av免费看 | 热久久精品在线 | 高清免费在线视频 | 欧美日韩一区二区三区在线观看视频 | 久久精品1区| 黄色一集片 | 成人国产精品久久久久久亚洲 | 99精品久久久 | 国产99一区二区 | 国产一区免费 | 亚洲 中文字幕av | www.黄色片网站 | 国产高清视频在线播放 |