日韩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团体程序设计天梯赛-决赛-部分题解的全部內容,希望文章能夠幫你解決所遇到的問題。

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

日本精品一区二区三区在线观看 | 亚洲乱码久久久 | 国产精品岛国久久久久久久久红粉 | 91伊人久久大香线蕉蜜芽人口 | 美女很黄免费网站 | av品善网| 999国产在线 | 中文字幕久久精品 | 亚洲最新精品 | 久99久中文字幕在线 | 国产黄色精品 | 天天摸天天舔 | 91爱爱免费观看 | 深夜国产在线 | 精品国产一区二区三区久久影院 | 中文字幕av在线电影 | 日韩啪视频 | 免费黄色av. | 久久精品综合视频 | 日韩av成人免费看 | 欧美贵妇性狂欢 | 日韩欧美视频 | 六月丁香激情网 | 亚洲永久免费av | 在线 国产 亚洲 欧美 | 天天色天天操天天爽 | 免费av在 | 精精国产xxxx视频在线播放 | 菠萝菠萝在线精品视频 | 亚洲综合在线观看视频 | 人人射网站 | 国产精品综合久久久久 | 中文字幕在线播放一区 | 欧美日韩亚洲在线 | 久久网页| 亚洲经典在线 | 国产一级片免费视频 | 久久亚洲热| 国产91电影在线观看 | 久久免费片 | 久久美女高清视频 | 免费视频91蜜桃 | 国产在线观看一 | 国产高清av免费在线观看 | www久久| 免费av成人在线 | 在线91视频 | 国产一级久久久 | 国产精品久久久久高潮 | 精品人人人人 | 超碰国产在线 | 97人人超碰在线 | 欧美999 | 久久天天综合网 | 激情五月综合网 | 欧美三级在线播放 | 在线成人看片 | a天堂一码二码专区 | 国产成人精品久久久久 | 九九热久久久 | 在线观看www. | 国产亚洲aⅴaaaaaa毛片 | 亚洲国产激情 | 久久久久久免费视频 | 久久久精品国产免费观看同学 | 激情五月播播久久久精品 | 88av色 | 国产精品久久久久久久久免费看 | 国产精品毛片一区二区 | 国产情侣一区 | 天天爱天天操天天干 | 亚洲视频高清 | 久久久久久久福利 | 日韩精品在线看 | 久久人人爽视频 | av在线进入| 成 人 免费 黄 色 视频 | 久草视频在线新免费 | 日韩欧美在线视频一区二区 | 午夜精品电影一区二区在线 | 日韩精品中文字幕在线观看 | 国产精品乱码高清在线看 | 久久久久久久久久久久久国产精品 | 欧美 日韩精品 | 中文字幕123区 | 欧美日韩在线视频免费 | 欧美日韩中文视频 | 亚洲aⅴ乱码精品成人区 | 91豆麻精品91久久久久久 | 日韩在线播放视频 | 久热电影 | 视频成人免费 | 亚洲黄色三级 | 久久五月情影视 | 69精品在线 | 欧美日在线 | 亚洲精品一区二区网址 | 91九色视频网站 | 五月天综合 | 成人av免费在线观看 | 91精品综合在线观看 | 久久艹艹 | 欧美成人xxxx | 99久久久成人国产精品 | 毛片一区二区 | 九九日韩| 综合伊人久久 | 96久久精品 | 亚洲国产理论片 | 久草久 | 午夜精品一区二区三区四区 | 亚洲精品字幕在线 | 欧美在线视频二区 | 久久黄色网址 | 国产91粉嫩白浆在线观看 | 久久亚洲电影 | 91麻豆视频| 国产一区网址 | 亚洲综合婷婷 | 国产在线色 | 久久精品香蕉视频 | 免费网址在线播放 | 日韩欧美国产视频 | 久久精品国产一区二区电影 | 一区二区三区久久 | 人人插人人看 | 精品亚洲视频在线 | 中文字幕在线人 | 国产精品亚洲综合久久 | 亚洲色图美腿丝袜 | 亚洲高清在线精品 | 69精品久久 | 四虎影视av | 五月婷婷狠狠 | 夜夜爽夜夜操 | 五月婷婷色 | 国产激情电影综合在线看 | 在线观看久 | 日韩欧美在线第一页 | 夜夜视频资源 | 69国产在线观看 | 日韩精品视频在线观看网址 | 国产精品久一 | 欧美乱熟臀69xxxxxx | 久久狠狠婷婷 | 中文高清av | 视频在线精品 | 婷婷色 亚洲 | 在线a人片免费观看视频 | 中文字幕av日韩 | 日韩在线视频一区二区三区 | 国产精品电影一区二区 | 91亚洲精品久久久蜜桃 | 亚洲国产中文字幕在线 | 天天草av| 国产在线a免费观看 | 亚洲精品777| 久草在线免费新视频 | 欧美一区二区伦理片 | 亚洲国产日韩精品 | 亚洲国产精品久久久久久 | 国产精品久久久久影院 | 国内综合精品午夜久久资源 | 黄色一级免费 | 天天做天天爽 | 欧美91精品久久久久国产性生爱 | 国产黄色片网站 | 国产一级视屏 | 久久爽久久爽久久av东京爽 | 国产一级视频在线 | 国产免费高清视频 | 久久久久 | 日本系列中文字幕 | 亚洲最大的av网站 | 91中文视频 | 天天翘av| a天堂免费 | 96av在线视频| 欧美日韩调教 | 在线视频app | 久久观看最新视频 | 99久热在线精品视频观看 | 国产淫片免费看 | 成人免费看片网址 | 日韩精品首页 | 超碰免费观看 | 日本精a在线观看 | 97超碰人人澡人人爱 | www久久精品 | 99视频在线 | 免费亚洲视频 | 韩国一区二区在线观看 | 免费在线观看午夜视频 | 久久综合狠狠综合久久综合88 | 韩国av免费观看 | 久久久精品国产一区二区 | 特级毛片在线免费观看 | 超碰电影在线观看 | 国产亚洲精品久久久久5区 成人h电影在线观看 | 久久久精品国产免费观看一区二区 | 亚洲综合精品视频 | 日韩aⅴ视频| 国产午夜精品免费一区二区三区视频 | 日韩黄色大片在线观看 | 久久久www| 玖玖在线观看视频 | 新av在线| 欧美一级性 | 92精品国产成人观看免费 | 亚洲欧美日韩国产一区二区三区 | 在线免费高清 | 97超碰免费在线 | 欧美性生交大片免网 | 国产美女在线精品免费观看 | 亚洲免费精品视频 | 国产精品成人aaaaa网站 | 精品久久久久久亚洲综合网站 | 国产女v资源在线观看 | 一 级 黄 色 片免费看的 | 欧美91在线 | 日本爱爱片 | www.操.com | 国内揄拍国内精品 | 久久综合色天天久久综合图片 | 国产一区二区三区免费视频 | 欧美日韩xxxxx | 久久久久久久久久久久影院 | 国产丝袜 | 免费久久视频 | 99在线观看免费视频精品观看 | 激情综合亚洲精品 | 99久久精品久久久久久清纯 | 久草线| 伊人资源视频在线 | 丁香六月天婷婷 | 视频三区在线 | 日韩一区二区三区免费视频 | 亚洲专区中文字幕 | 国产成人61精品免费看片 | 日韩午夜电影院 | 丁香婷婷色综合亚洲电影 | 天天射天天干天天爽 | 国产黄色片网站 | 精品在线二区 | 性色va| 成人av视屏 | 干天天 | 亚洲国产精品免费 | 亚州精品视频 | 中文字幕在线观看不卡 | 九九精品视频在线观看 | 日韩大片免费在线观看 | 天天干天天色2020 | 国产精品久久一区二区无卡 | 亚洲最新毛片 | 精品91久久久久 | 00av视频| 免费十分钟 | 国产精品国产三级国产不产一地 | 国产在线视频一区二区三区 | 色偷偷男人的天堂av | 狠狠色丁香婷婷综合 | 亚洲精品国产精品久久99热 | 高清有码中文字幕 | 狠狠操导航| 色.www| 国产精品原创在线 | 午夜91视频 | 亚洲激情影院 | 国产韩国日本高清视频 | 日韩av中文字幕在线 | 99精品视频一区二区 | 天天爽人人爽夜夜爽 | 九九久久国产精品 | 久久国产品 | 亚洲精品国偷拍自产在线观看 | 国产精品精品久久久久久 | 午夜精品一区二区三区在线播放 | 国产精品麻豆视频 | 天堂av最新网址 | 99久久精品免费看国产麻豆 | 亚洲视频1区2区 | 特级西西444www大胆高清无视频 | 四虎国产精品成人免费影视 | 国产一区二区久久久 | 久久高清国产 | 免费a视频 | www婷婷| 国产精品成人一区二区三区 | 亚洲国产一区二区精品专区 | 日韩欧美第二页 | 免费看国产黄色 | 91超碰免费在线 | 免费污片 | 国产亚洲视频在线 | 国产一级电影网 | 在线看一级片 | 在线免费黄色 | 亚洲精品国产精品久久99热 | 麻豆视频免费播放 | 99精品热视频 | 亚洲影视九九影院在线观看 | 欧美日韩在线免费观看视频 | 丰满少妇久久久 | 在线观看视频97 | 日韩电影在线观看中文字幕 | 国产精品综合久久久久 | 久久极品 | 黄色三级免费片 | 国产一级做a爱片久久毛片a | 国产精品一区二区三区视频免费 | 亚洲国内精品在线 | 国产欧美在线一区二区三区 | 国产一区二区精品 | 婷婷日日 | 亚洲精品视频久久 | www夜夜| 国内精品久久久久久久久 | 亚洲国内精品视频 | 亚洲午夜精| 综合激情久久 | 成人久久综合 | 亚洲老妇xxxxxx | 色综合天天视频在线观看 | 久久高清片| 亚洲综合在线发布 | www色av| 岛国精品一区二区 | 亚洲一区二区高潮无套美女 | 精品毛片一区二区免费看 | 久久久黄色 | 韩日视频在线 | 奇米影音四色 | 香蕉精品在线观看 | av中文天堂在线 | 久久久久久久久久久国产精品 | 久久久高清视频 | 亚洲精品国产精品国自产观看 | 亚洲爽爽网 | 天天综合色天天综合 | 亚洲午夜久久久综合37日本 | 中国一级片在线播放 | 亚洲综合色av | 日韩免费视频 | 18久久久| 激情五月婷婷综合 | 在线成人短视频 | 免费日韩电影 | 亚洲三级黄色 | 天天色天天操天天爽 | 在线va网站| 黄色精品视频 | 久久久这里有精品 | 国产中文字幕亚洲 | 久久黄视频 | jizz999| 国产1区2区3区在线 亚洲自拍偷拍色图 | 黄色官网在线观看 | 久久免费一级片 | 欧美日本不卡视频 | 国内精品在线观看视频 | 激情综合婷婷 | 91福利在线观看 | 午夜色站 | 黄色软件视频大全免费下载 | av先锋中文字幕 | 国产精品二区在线 | 亚洲国产精品久久 | 91手机视频 | 永久av免费在线观看 | 免费看三级黄色片 | 国产免费久久久久 | 亚洲国产精品视频 | 欧美视频日韩 | 在线免费观看视频一区 | 久久久久久久影院 | 黄色片网站大全 | 亚洲精品在 | 国产夫妻av在线 | 国产又粗又猛又黄视频 | 99国内精品久久久久久久 | 久久精品综合网 | 在线视频日韩精品 | 999久久久免费视频 午夜国产在线观看 | 欧美日韩高清不卡 | 久久精品欧美一 | 奇米网8888 | 在线91色 | 久久人人爽人人爽人人片av软件 | av综合站 | 日韩视频一区二区在线观看 | 欧美午夜久久 | 国产精品久久久一区二区三区网站 | 丁香六月久久综合狠狠色 | 91成人精品在线 | 久久久av电影 | 69成人在线| 在线播放一区二区三区 | 黄色av一级 | 国产又粗又长又硬免费视频 | 日韩电影在线看 | 亚洲欧美日韩不卡 | 日韩在线观看免费 | 日韩在线免费高清视频 | 91在线精品一区二区 | 波多野结衣视频网址 | 久久激情视频网 | 99国产免费网址 | 亚洲人成人99网站 | 久久五月情影视 | 成人黄色毛片视频 | 97精品超碰一区二区三区 | av天天在线观看 | 国产对白av | 国产精品6999成人免费视频 | 久久99热这里只有精品 | 欧美调教网站 | 国内少妇自拍视频一区 | 精品无人国产偷自产在线 | 伊人va| 免费日韩一区二区三区 | av免费在线看网站 | 波多野结衣在线视频一区 | 国产精品国产三级国产aⅴ入口 | 激情网综合 | 黄色成人av在线 | 欧美无极色 | 欧美日韩xxxxx| 国产理论影院 | 欧美日韩一区二区三区不卡 | 国产精品久久久久久久久费观看 | 国产精品破处视频 | 在线观看亚洲专区 | 欧美一级久久久 | 精品亚洲在线 | 美女视频黄是免费的 | 四虎在线观看 | 亚洲激情电影在线 | 美女视频黄是免费的 | 亚洲乱亚洲乱妇 | 国产精品免费观看在线 | 色之综合网 | 香蕉视频在线观看免费 | 精品国产一区二区三区在线观看 | 日韩videos | 粉嫩av一区二区三区入口 | 五月亚洲 | 国产九色在线播放九色 | 日韩在线免费 | 婷婷5月色 | 国产日韩视频在线播放 | 三级动态视频在线观看 | 99久久er热在这里只有精品15 | 在线看国产视频 | 欧美在线资源 | 婷婷激情五月 | 午夜久草| 国产日韩欧美在线免费观看 | 操处女逼 | 99国产精品一区 | 波多野结衣一区二区三区中文字幕 | 久久精品在线免费观看 | 超碰在线最新 | 久草在线资源观看 | 亚洲人xxx| 免费在线观看av的网站 | 蜜臀久久99静品久久久久久 | 伊人热 | 在线观看国产成人av片 | 久久精品一区二区三 | 香蕉久草 | 国产精品久久久久久久久岛 | 久久天堂网站 | 91黄色成人| 免费在线观看一区二区三区 | 久久人人爽人人爽人人片 | 久久精品www人人爽人人 | 久久久久久久久久久久久国产精品 | 欧美视频在线观看免费网址 | 亚洲国产欧美在线看片xxoo | 久久99九九99精品 | 久久福利小视频 | 国产一区二区日本 | 欧美贵妇性狂欢 | 中文字幕在线观看第三页 | 国产专区精品视频 | 成人a免费视频 | 97涩涩视频 | 久久久免费 | 韩国三级在线一区 | 亚洲永久精品在线 | 97免费视频在线 | 日韩电影一区二区在线 | 精品播放| 亚洲欧美日韩国产精品一区午夜 | 综合国产在线 | www.精选视频.com | 色资源网免费观看视频 | 日本电影久久 | 91在线免费播放视频 | 国产高清99 | 激情婷婷久久 | 日韩精品专区在线影院重磅 | 成人黄色小说在线观看 | 97碰视频| 99re久久资源最新地址 | 成人精品国产免费网站 | 国产精品永久免费 | 亚洲综合在线五月 | wwwwww黄| 国产在线国产 | 成人午夜电影在线 | 欧美一区二区免费在线观看 | 久久综合九色 | 国产永久免费高清在线观看视频 | 国产91精品在线播放 | 国产99视频在线观看 | 久久久久久久久久久久99 | 久草视频在线看 | 国产精品刺激对白麻豆99 | 最新av免费在线 | 中文字幕视频在线播放 | 99视频免费观看 | 国内精品二区 | 亚洲 欧美 91| 久久久久美女 | 亚洲国产成人高清精品 | 一级黄色片在线免费观看 | 国产夫妻性生活自拍 | 中文字幕乱码电影 | 天天射天天拍 | 日韩成人免费在线观看 | www.国产在线视频 | 在线欧美中文字幕 | 在线蜜桃视频 | 亚洲天堂网站视频 | 亚洲国产wwwccc36天堂 | 国产视频在线观看一区 | www.五月天婷婷.com | 精品美女在线视频 | 国产成人精品一区二区在线观看 | 国产一区二区三区四区在线 | 丁香六月久久综合狠狠色 | 日韩艹 | 99在线观看免费视频精品观看 | 插综合网| 免费中文字幕在线观看 | 黄色软件在线观看免费 | 亚洲一区二区三区在线看 | 成人97人人超碰人人99 | 婷婷久草 | 中文字幕av播放 | 精品久久久久国产免费第一页 | 伊人在线视频 | 国产粉嫩在线 | 国产裸体无遮挡 | 天天插视频| 日韩电影精品 | 国产精品国产三级国产专区53 | 欧美男同视频网站 | 欧美日韩一区二区三区不卡 | 狠狠干夜夜操天天爽 | 综合网伊人 | 国产精品黑丝在线观看 | 精品久久久久久亚洲 | 欧美少妇bbwhd | 国产不卡在线播放 | 国产高清一区二区 | 亚洲天堂网在线视频 | 日本资源中文字幕在线 | 99视屏 | 久久久黄色 | 99视频久久 | 特级西西人体444是什么意思 | 91中文字幕视频 | 免费看色的网站 | 亚洲国产操 | 天天插一插 | 国产午夜精品一区二区三区欧美 | 亚洲尺码电影av久久 | .国产精品成人自产拍在线观看6 | 在线a人v观看视频 | 免费日韩视频 | 99精品视频网| 亚洲国产精品一区二区久久,亚洲午夜 | 欧美日韩国产亚洲乱码字幕 | 99免费精品 | 激情片av | 久久精品亚洲一区二区三区观看模式 | av中文字幕免费在线观看 | 91看片看淫黄大片 | 91视频 - v11av| 久久99国产视频 | 久久免费精彩视频 | 精品96久久久久久中文字幕无 | 最新99热 | 天天干,天天干 | 丰满少妇在线观看 | 色欧美日韩 | 国产精品福利在线观看 | 美女视频黄色免费 | 国产中文字幕在线观看 | 久久久麻豆视频 | 免费看国产精品 | 麻豆视频免费版 | 91在线观 | www黄在线 | 久草在线视频中文 | 国产精品v a免费视频 | 日日夜操| 天天曰| 中文字幕亚洲五码 | 婷婷激情影院 | 97视频网站 | 日韩在线大片 | 天堂黄色片 | 日韩精品在线免费观看 | 草久在线观看视频 | 500部大龄熟乱视频 欧美日本三级 | 国产精品视频你懂的 | 中午字幕在线观看 | 欧美国产高清 | 欧美色图视频一区 | 中文字幕韩在线第一页 | 日韩在线观看 | 在线 你懂 | 国内精品久久久久影院优 | 成人免费网站视频 | 成人免费在线观看av | av在线影片 | 在线观看av不卡 | 国产一区二区不卡视频 | 国产又粗又猛又爽又黄的视频先 | 在线观看深夜视频 | 最近免费中文字幕mv在线视频3 | 超碰成人av | 人人爽人人插 | 中文字幕黄色网 | 81精品国产乱码久久久久久 | 高潮久久久久久 | 日本性xxxxx| 欧美日韩国产综合网 | 四虎影视成人永久免费观看视频 | 欧美精品v国产精品v日韩精品 | 午夜国产一区二区三区四区 | 91免费高清 | 成年人在线免费视频观看 | 玖玖爱在线观看 | 亚洲jizzjizz日本少妇 | 中文字幕av免费 | 亚洲精品黄色在线观看 | 丁香婷婷综合激情 | 国产精品免费视频观看 | 久草在线欧美 | 国产精品ⅴa有声小说 | 日本精品午夜 | 久久久免费高清视频 | 91精品一区二区三区蜜桃 | 日韩中文字幕一区 | 久久久久久久国产精品 | 8x成人在线| 中文字幕丰满人伦在线 | 精品久久久久久久久久岛国gif | 日韩有码网站 | 高清av网站 | 人人玩人人添人人 | 天天操偷偷干 | 日韩中文字幕电影 | 一区二区三区四区五区在线 | 久久欧美在线电影 | 国产不卡精品 | 国产不卡精品视频 | 欧美日高清视频 | 欧美福利在线播放 | 欧美va电影 | 在线国产小视频 | 黄色的片子 | 99精品国产一区二区三区不卡 | 99se视频在线观看 | 在线视频免费观看 | 久久97久久 | 五月天欧美精品 | 中文国产字幕 | 九九九热精品 | 狠狠综合 | 国产中文字幕91 | 91精品久久久久久久久久入口 | 国产午夜精品久久久久久久久久 | 久久久久久久久影院 | 夜夜干夜夜 | 国产免费叼嘿网站免费 | 91精品国自产在线偷拍蜜桃 | 99久视频 | 国产麻豆精品一区二区 | 亚洲精品一区二区久 | 美女性爽视频国产免费app | 国产在线观看中文字幕 | 色欧美日韩 | 免费三级骚 | www.夜夜| av 一区 二区 久久 | 色欲综合视频天天天 | 天堂v中文 | 911香蕉视频 | 最近中文字幕完整视频高清1 | 中文字幕影片免费在线观看 | 亚洲美女视频网 | 欧美视频二区 | 午夜av在线播放 | 97福利视频| 在线观看成年人 | 国产在线国偷精品产拍 | 亚洲成年人av | 91福利视频一区 | 国产原厂视频在线观看 | 国产日韩在线播放 | 亚洲精品视频免费观看 | 欧美国产视频在线 | 国产理论一区二区三区 | 丁香婷婷综合五月 | 日韩免费电影在线观看 | 中文字幕有码在线 | 成人黄色大片在线免费观看 | 免费国产一区二区视频 | 在线影视 一区 二区 三区 | 黄色中文字幕在线 | 精品亚洲va在线va天堂资源站 | 91成人短视频在线观看 | 国产黄在线播放 | 天天操综 | 久久国产精品视频免费看 | 在线婷婷 | 久久综合狠狠综合久久狠狠色综合 | 国产精品久久一区二区三区, | 欧美成人xxxx | 精品视频123区在线观看 | 狠狠伊人 | 久久视频热| 亚洲美女精品视频 | 9999免费视频| 嫩小bbbb摸bbb摸bbb | 久久久久久久久久毛片 | 色噜噜日韩精品一区二区三区视频 | 欧美国产高清 | 久久国产区 | 日本99久久 | 久久精品在线 | www.五月婷婷 | 97香蕉久久国产在线观看 | 中文不卡视频在线 | av日韩国产 | a黄色片在线观看 | 色婷婷综合久久久久中文字幕1 | 天天射天天干天天插 | www.午夜| 国产九九精品视频 | 久久久午夜精品理论片中文字幕 | a级国产乱理论片在线观看 伊人宗合网 | 天天综合精品 | 又色又爽又黄高潮的免费视频 | 成人国产精品一区 | 成人国产电影在线观看 | 激情av网址 | 欧美在线观看视频 | 日韩系列在线 | 在线观看亚洲专区 | 国产精品美女视频网站 | 成年人黄色免费看 | 天天综合天天做天天综合 | 四虎8848免费高清在线观看 | 91在线网址 | 欧美在线视频a | 国内精品国产三级国产aⅴ久 | 色噜噜在线观看 | 在线成人一区 | 91黄色影视 | www.亚洲激情.com | 手机看片国产 | 成人av免费看 | 91久久国产露脸精品国产闺蜜 | av免费在线观看网站 | 成人免费在线电影 | 亚洲国产精品电影 | 亚洲最快最全在线视频 | 亚洲高清国产视频 | 久久草网站 | 国产在线精品区 | 五月婷久 | 精品夜夜嗨av一区二区三区 | 五月天色中色 | 国产福利小视频在线 | 综合网伊人 | 91麻豆文化传媒在线观看 | www一起操| 最新的av网站| av中文天堂 | 亚洲影视九九影院在线观看 | 国产一区免费观看 | 黄av免费 | 国产精品99久久久久久久久 | 九九九在线观看视频 | 17婷婷久久www | 激情视频综合网 | 日韩高清在线观看 | 日本系列中文字幕 | 久久久久国产一区二区三区四区 | 国产精品嫩草影视久久久 | 综合婷婷丁香 | 亚洲免费成人av电影 | 亚洲va欧美va人人爽 | 欧美精品久久久久久久久久久 | 91视频国产免费 | 日韩一级电影在线观看 | 日韩电影中文字幕在线观看 | 久章操| 久久久久久久久免费 | 一二区精品 | 国产一区影院 | 天天草夜夜 | 国产又粗又猛又色又黄视频 | 黄色成人在线观看 | 天天做天天爱夜夜爽 | 日日夜夜精品免费视频 | 成人在线观看资源 | 又爽又黄在线观看 | 91精品国产电影 | 国产精品毛片一区二区三区 | 色婷婷在线播放 | www.黄色片.com | 97看片| 国产精品日韩欧美一区二区 | 激情丁香婷婷 | 日韩欧美精品在线视频 | 日本福利视频在线 | 国产精品va | 中文字幕欧美日韩va免费视频 | 国产精品第7页 | 正在播放国产一区 | 久久精品美女视频 | 天天射网站 | 波多野结衣在线播放一区 | 在线免费观看欧美日韩 | 国产69熟 | 中文字幕在线久一本久 | 国产亚洲视频在线 | 久一久久 | 国产在线一区观看 | 日韩二区精品 | 精品国产一区二区三区蜜臀 | 中文字幕精品一区 | 伊人黄| 国产精品扒开做爽爽的视频 | 91手机在线看片 | 国产精品国产三级国产专区53 | 日韩欧美在线免费观看 | 国产精品久久中文字幕 | www.五月天婷婷.com | 夜夜婷婷| 久草在线视频看看 | 欧美大荫蒂xxx | 国产天天爽 | 五月婷婷在线观看视频 | 国产91探花 | 日韩精选在线观看 | 婷婷色综合色 | 久久国色夜色精品国产 | 国产精品一区在线 | 免费观看国产精品 | 国产精品二区在线观看 | 亚洲成人欧美 | 精品国产一区二区三区男人吃奶 | 91精品久| 久草在线久| 久久久久成人精品 | 中文字幕在线观 | 超碰人人草人人 | 91福利在线观看 | 成人va视频 | 国产精品久久久久久久久久 | av线上看| 国产成人91 | 免费在线观看毛片网站 | 国产尤物在线观看 | 成人av资源网 | 日韩电影一区二区在线观看 | 一区二区不卡 | 久久任你操 | 日本激情视频中文字幕 | 色婷婷久久 | 久久综合久久综合久久综合 | 国产剧情一区二区 | www.啪啪.com | 在线观看视频在线观看 | 欧美激情视频在线观看免费 | av福利资源 | 日韩精品综合在线 | 亚洲精品三级 | 在线成人高清电影 | 成人av高清在线 | www.久久久精品 | 国产自产在线视频 | 在线日韩中文 | 国产1级视频 | 伊人五月婷 | 国产99色 | 久久久久久久久久久免费视频 | 中文字幕在线看片 | 国产69精品久久久久99 | 国产老妇av | 天天操天天操天天操 | 中国一 片免费观看 | 一区二区精品视频 | 精品中文字幕视频 | 99在线视频免费观看 | 日韩视频一区二区在线观看 | 日本在线观看一区二区三区 | 精品国产一区二区三区久久久 | 少妇啪啪av入口 | 香蕉蜜桃视频 | 中文字幕一区av | 国产经典av | 91在线免费公开视频 | 国产精品久久久久久久久费观看 | 国产毛片久久 | 免费看日韩片 | 91麻豆福利 | 1024手机基地在线观看 | 午夜av在线播放 | 国产一区二区高清视频 | 国产日韩欧美在线看 | 麻豆精品传媒视频 | 国产精国产精品 | 欧美精品v国产精品 | 91免费在线播放 | 在线婷婷 | 日韩在线中文字幕 | 国产精品一区二区免费在线观看 | 99re国产| 在线小视频 | 久久久久久久久久久综合 | 亚洲精品视频免费在线 | 狠狠干狠狠艹 | 国产精品美女久久久网av | 麻豆精品传媒视频 | 91麻豆福利| 日韩高清免费电影 | 精品久久国产精品 | 国产精品久久久久久久久大全 | 天天干天天想 | 麻豆成人精品视频 | 99re国产| 欧美精品乱码久久久久久 | 99在线精品免费视频九九视 | 深爱激情综合 | 又色又爽又黄 | 亚洲精品中文字幕视频 | 午夜色性片 | 在线之家免费在线观看电影 | 欧美日韩精品在线观看 | 视频在线观看99 | 国产日产精品一区二区三区四区的观看方式 | 天天操操 | 国产精品色 | 免费观看一区二区三区视频 | 91免费观看 | 免费看av片网站 | 337p日本大胆噜噜噜噜 | 国产精品亚洲综合久久 | www.天堂av| 欧美一区二区精品在线 | 97超视频 | 视频在线观看亚洲 | 九九热在线播放 | 成人黄色小说视频 | 在线精品亚洲 | 国产美女网站视频 | av一级免费 | 亚洲精品合集 | 看黄色.com | 国产精品露脸在线 | www.色com | 亚洲欧美日韩精品久久久 | 久草资源在线观看 | 国产成人精品网站 | 三级免费黄色 | 97超碰人人澡人人爱 | 欧美福利视频 | 高清不卡一区二区三区 | a级国产乱理伦片在线播放 久久久久国产精品一区 | 51久久成人国产精品麻豆 | 99久久久成人国产精品 | 91免费网站在线观看 | 精品视频www | 日韩av在线高清 | 激情视频91 | 国内成人精品2018免费看 | 亚州av免费| 免费高清av在线看 |