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

歡迎訪問 生活随笔!

生活随笔

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

编程问答

2016 Multi-University Training Contest 3

發布時間:2024/4/14 编程问答 50 豆豆
生活随笔 收集整理的這篇文章主要介紹了 2016 Multi-University Training Contest 3 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

A -?Sqrt Bo

簽到題啦,直接套一個大數模板搞定。

不過我現在使用的大數模板不支持直接定義并賦值,bignum a = 1 這樣是不行的。

  
  //查看了下代碼發現,模板中bignum的構造函數,只有這一個,也就是定義一個大數,初始化為0(num[0]非0位數)
  inline bignum(){memset(num,
0,sizeof(bignum_t));num[0]=1 ;sgn=0 ;}

有因為模板中重載了=

inline bignum&operator=(const int a){memset(num,0,sizeof(bignum_t));num[0]=1 ;sgn=SGN (a);add(num,sgn*a);return*this ;}

所以可以采用:

bignum a;

a = 1233;

這種方法來定義一個靜態大數。

// // main.cpp // multi2016.2.firtst // // Created by New_Life on 16/8/1. // Copyright ? 2016年 chenhuan001. All rights reserved. // #include <iostream> #include <math.h> #include <stdio.h> #include <algorithm> #include <string.h> using namespace std;#define DIGIT 4 //四位隔開,即萬進制 #define DEPTH 10000 //萬進制 #define MAX 30 //題目最大位數/4,要不大直接設為最大位數也行 typedef int bignum_t[MAX+1];/************************************************************************/ /* 讀取操作數,對操作數進行處理存儲在數組里 */ /************************************************************************/ int read(bignum_t a,istream&is=cin) {char buf[MAX*DIGIT+1],ch ;int i,j ;memset((void*)a,0,sizeof(bignum_t));if(!(is>>buf))return 0 ;for(a[0]=strlen(buf),i=a[0]/2-1;i>=0;i--)ch=buf[i],buf[i]=buf[a[0]-1-i],buf[a[0]-1-i]=ch ;for(a[0]=(a[0]+DIGIT-1)/DIGIT,j=strlen(buf);j<a[0]*DIGIT;buf[j++]='0');for(i=1;i<=a[0];i++)for(a[i]=0,j=0;j<DIGIT;j++)a[i]=a[i]*10+buf[i*DIGIT-1-j]-'0' ;for(;!a[a[0]]&&a[0]>1;a[0]--);return 1 ; }void write(const bignum_t a,ostream&os=cout) {int i,j ;for(os<<a[i=a[0]],i--;i;i--)for(j=DEPTH/10;j;j/=10)os<<a[i]/j%10 ; }int comp(const bignum_t a,const bignum_t b) {int i ;if(a[0]!=b[0])return a[0]-b[0];for(i=a[0];i;i--)if(a[i]!=b[i])return a[i]-b[i];return 0 ; }int comp(const bignum_t a,const int b) {int c[12]={};for(c[1]=b;c[c[0]]>=DEPTH;c[c[0]+1]=c[c[0]]/DEPTH,c[c[0]]%=DEPTH,c[0]++);return comp(a,c); }int comp(const bignum_t a,const int c,const int d,const bignum_t b) {int i,t=0,O=-DEPTH*2 ;if(b[0]-a[0]<d&&c)return 1 ;for(i=b[0];i>d;i--){t=t*DEPTH+a[i-d]*c-b[i];if(t>0)return 1 ;if(t<O)return 0 ;}for(i=d;i;i--){t=t*DEPTH-b[i];if(t>0)return 1 ;if(t<O)return 0 ;}return t>0 ; } /************************************************************************/ /* 大數與大數相加 */ /************************************************************************/ void add(bignum_t a,const bignum_t b) {int i ;for(i=1;i<=b[0];i++)if((a[i]+=b[i])>=DEPTH)a[i]-=DEPTH,a[i+1]++;if(b[0]>=a[0])a[0]=b[0];elsefor(;a[i]>=DEPTH&&i<a[0];a[i]-=DEPTH,i++,a[i]++);a[0]+=(a[a[0]+1]>0); } /************************************************************************/ /* 大數與小數相加 */ /************************************************************************/ void add(bignum_t a,const int b) {int i=1 ;for(a[1]+=b;a[i]>=DEPTH&&i<a[0];a[i+1]+=a[i]/DEPTH,a[i]%=DEPTH,i++);for(;a[a[0]]>=DEPTH;a[a[0]+1]=a[a[0]]/DEPTH,a[a[0]]%=DEPTH,a[0]++); } /************************************************************************/ /* 大數相減(被減數>=減數) */ /************************************************************************/ void sub(bignum_t a,const bignum_t b) {int i ;for(i=1;i<=b[0];i++)if((a[i]-=b[i])<0)a[i+1]--,a[i]+=DEPTH ;for(;a[i]<0;a[i]+=DEPTH,i++,a[i]--);for(;!a[a[0]]&&a[0]>1;a[0]--); } /************************************************************************/ /* 大數減去小數(被減數>=減數) */ /************************************************************************/ void sub(bignum_t a,const int b) {int i=1 ;for(a[1]-=b;a[i]<0;a[i+1]+=(a[i]-DEPTH+1)/DEPTH,a[i]-=(a[i]-DEPTH+1)/DEPTH*DEPTH,i++);for(;!a[a[0]]&&a[0]>1;a[0]--); }void sub(bignum_t a,const bignum_t b,const int c,const int d) {int i,O=b[0]+d ;for(i=1+d;i<=O;i++)if((a[i]-=b[i-d]*c)<0)a[i+1]+=(a[i]-DEPTH+1)/DEPTH,a[i]-=(a[i]-DEPTH+1)/DEPTH*DEPTH ;for(;a[i]<0;a[i+1]+=(a[i]-DEPTH+1)/DEPTH,a[i]-=(a[i]-DEPTH+1)/DEPTH*DEPTH,i++);for(;!a[a[0]]&&a[0]>1;a[0]--); } /************************************************************************/ /* 大數相乘,讀入被乘數a,乘數b,結果保存在c[] */ /************************************************************************/ void mul(bignum_t c,const bignum_t a,const bignum_t b) {int i,j ;memset((void*)c,0,sizeof(bignum_t));for(c[0]=a[0]+b[0]-1,i=1;i<=a[0];i++)for(j=1;j<=b[0];j++)if((c[i+j-1]+=a[i]*b[j])>=DEPTH)c[i+j]+=c[i+j-1]/DEPTH,c[i+j-1]%=DEPTH ;for(c[0]+=(c[c[0]+1]>0);!c[c[0]]&&c[0]>1;c[0]--); } /************************************************************************/ /* 大數乘以小數,讀入被乘數a,乘數b,結果保存在被乘數 */ /************************************************************************/ void mul(bignum_t a,const int b) {int i ;for(a[1]*=b,i=2;i<=a[0];i++){a[i]*=b ;if(a[i-1]>=DEPTH)a[i]+=a[i-1]/DEPTH,a[i-1]%=DEPTH ;}for(;a[a[0]]>=DEPTH;a[a[0]+1]=a[a[0]]/DEPTH,a[a[0]]%=DEPTH,a[0]++);for(;!a[a[0]]&&a[0]>1;a[0]--); }void mul(bignum_t b,const bignum_t a,const int c,const int d) {int i ;memset((void*)b,0,sizeof(bignum_t));for(b[0]=a[0]+d,i=d+1;i<=b[0];i++)if((b[i]+=a[i-d]*c)>=DEPTH)b[i+1]+=b[i]/DEPTH,b[i]%=DEPTH ;for(;b[b[0]+1];b[0]++,b[b[0]+1]=b[b[0]]/DEPTH,b[b[0]]%=DEPTH);for(;!b[b[0]]&&b[0]>1;b[0]--); } /**************************************************************************/ /* 大數相除,讀入被除數a,除數b,結果保存在c[]數組 */ /* 需要comp()函數 */ /**************************************************************************/ void div(bignum_t c,bignum_t a,const bignum_t b) {int h,l,m,i ;memset((void*)c,0,sizeof(bignum_t));c[0]=(b[0]<a[0]+1)?(a[0]-b[0]+2):1 ;for(i=c[0];i;sub(a,b,c[i]=m,i-1),i--)for(h=DEPTH-1,l=0,m=(h+l+1)>>1;h>l;m=(h+l+1)>>1)if(comp(b,m,i-1,a))h=m-1 ;else l=m ;for(;!c[c[0]]&&c[0]>1;c[0]--);c[0]=c[0]>1?c[0]:1 ; }void div(bignum_t a,const int b,int&c) {int i ;for(c=0,i=a[0];i;c=c*DEPTH+a[i],a[i]=c/b,c%=b,i--);for(;!a[a[0]]&&a[0]>1;a[0]--); } /************************************************************************/ /* 大數平方根,讀入大數a,結果保存在b[]數組里 */ /* 需要comp()函數 */ /************************************************************************/ void sqrt(bignum_t b,bignum_t a) {int h,l,m,i ;memset((void*)b,0,sizeof(bignum_t));for(i=b[0]=(a[0]+1)>>1;i;sub(a,b,m,i-1),b[i]+=m,i--)for(h=DEPTH-1,l=0,b[i]=m=(h+l+1)>>1;h>l;b[i]=m=(h+l+1)>>1)if(comp(b,m,i-1,a))h=m-1 ;else l=m ;for(;!b[b[0]]&&b[0]>1;b[0]--);for(i=1;i<=b[0];b[i++]>>=1); } /************************************************************************/ /* 返回大數的長度 */ /************************************************************************/ int length(const bignum_t a) {int t,ret ;for(ret=(a[0]-1)*DIGIT,t=a[a[0]];t;t/=10,ret++);return ret>0?ret:1 ; } /************************************************************************/ /* 返回指定位置的數字,從低位開始數到第b位,返回b位上的數 */ /************************************************************************/ int digit(const bignum_t a,const int b) {int i,ret ;for(ret=a[(b-1)/DIGIT+1],i=(b-1)%DIGIT;i;ret/=10,i--);return ret%10 ; } /************************************************************************/ /* 返回大數末尾0的個數 */ /************************************************************************/ int zeronum(const bignum_t a) {int ret,t ;for(ret=0;!a[ret+1];ret++);for(t=a[ret+1],ret*=DIGIT;!(t%10);t/=10,ret++);return ret ; }void comp(int*a,const int l,const int h,const int d) {int i,j,t ;for(i=l;i<=h;i++)for(t=i,j=2;t>1;j++)while(!(t%j))a[j]+=d,t/=j ; }void convert(int*a,const int h,bignum_t b) {int i,j,t=1 ;memset(b,0,sizeof(bignum_t));for(b[0]=b[1]=1,i=2;i<=h;i++)if(a[i])for(j=a[i];j;t*=i,j--)if(t*i>DEPTH)mul(b,t),t=1 ;mul(b,t); } /************************************************************************/ /* 組合數 */ /************************************************************************/ void combination(bignum_t a,int m,int n) {int*t=new int[m+1];memset((void*)t,0,sizeof(int)*(m+1));comp(t,n+1,m,1);comp(t,2,m-n,-1);convert(t,m,a);delete[]t ; } /************************************************************************/ /* 排列數 */ /************************************************************************/ void permutation(bignum_t a,int m,int n) {int i,t=1 ;memset(a,0,sizeof(bignum_t));a[0]=a[1]=1 ;for(i=m-n+1;i<=m;t*=i++)if(t*i>DEPTH)mul(a,t),t=1 ;mul(a,t); }#define SGN(x) ((x)>0?1:((x)<0?-1:0)) #define ABS(x) ((x)>0?(x):-(x))int read(bignum_t a,int&sgn,istream&is=cin) {char str[MAX*DIGIT+2],ch,*buf ;int i,j ;memset((void*)a,0,sizeof(bignum_t));if(!(is>>str))return 0 ;buf=str,sgn=1 ;if(*buf=='-')sgn=-1,buf++;for(a[0]=strlen(buf),i=a[0]/2-1;i>=0;i--)ch=buf[i],buf[i]=buf[a[0]-1-i],buf[a[0]-1-i]=ch ;for(a[0]=(a[0]+DIGIT-1)/DIGIT,j=strlen(buf);j<a[0]*DIGIT;buf[j++]='0');for(i=1;i<=a[0];i++)for(a[i]=0,j=0;j<DIGIT;j++)a[i]=a[i]*10+buf[i*DIGIT-1-j]-'0' ;for(;!a[a[0]]&&a[0]>1;a[0]--);if(a[0]==1&&!a[1])sgn=0 ;return 1 ; } struct bignum {bignum_t num ;int sgn ;public :inline bignum(){printf("!!!\n");memset(num,0,sizeof(bignum_t));num[0]=1 ;sgn=0 ;}inline int operator!(){return num[0]==1&&!num[1];}inline bignum&operator=(const bignum&a){memcpy(num,a.num,sizeof(bignum_t));sgn=a.sgn ;return*this ;}inline bignum&operator=(const int a){memset(num,0,sizeof(bignum_t));num[0]=1 ;sgn=SGN (a);add(num,sgn*a);return*this ;};inline bignum&operator+=(const bignum&a){if(sgn==a.sgn)add(num,a.num);else if(sgn&&a.sgn){int ret=comp(num,a.num);if(ret>0)sub(num,a.num);else if(ret<0){bignum_t t ;memcpy(t,num,sizeof(bignum_t));memcpy(num,a.num,sizeof(bignum_t));sub (num,t);sgn=a.sgn ;}else memset(num,0,sizeof(bignum_t)),num[0]=1,sgn=0 ;}else if(!sgn)memcpy(num,a.num,sizeof(bignum_t)),sgn=a.sgn ;return*this ;}inline bignum&operator+=(const int a){if(sgn*a>0)add(num,ABS(a));else if(sgn&&a){int ret=comp(num,ABS(a));if(ret>0)sub(num,ABS(a));else if(ret<0){bignum_t t ;memcpy(t,num,sizeof(bignum_t));memset(num,0,sizeof(bignum_t));num[0]=1 ;add(num,ABS (a));sgn=-sgn ;sub(num,t);}else memset(num,0,sizeof(bignum_t)),num[0]=1,sgn=0 ;}else if(!sgn)sgn=SGN(a),add(num,ABS(a));return*this ;}inline bignum operator+(const bignum&a){bignum ret ;memcpy(ret.num,num,sizeof (bignum_t));ret.sgn=sgn ;ret+=a ;return ret ;}inline bignum operator+(const int a){bignum ret ;memcpy(ret.num,num,sizeof (bignum_t));ret.sgn=sgn ;ret+=a ;return ret ;}inline bignum&operator-=(const bignum&a){if(sgn*a.sgn<0)add(num,a.num);else if(sgn&&a.sgn){int ret=comp(num,a.num);if(ret>0)sub(num,a.num);else if(ret<0){bignum_t t ;memcpy(t,num,sizeof(bignum_t));memcpy(num,a.num,sizeof(bignum_t));sub(num,t);sgn=-sgn ;}else memset(num,0,sizeof(bignum_t)),num[0]=1,sgn=0 ;}else if(!sgn)add (num,a.num),sgn=-a.sgn ;return*this ;}inline bignum&operator-=(const int a){if(sgn*a<0)add(num,ABS(a));else if(sgn&&a){int ret=comp(num,ABS(a));if(ret>0)sub(num,ABS(a));else if(ret<0){bignum_t t ;memcpy(t,num,sizeof(bignum_t));memset(num,0,sizeof(bignum_t));num[0]=1 ;add(num,ABS(a));sub(num,t);sgn=-sgn ;}else memset(num,0,sizeof(bignum_t)),num[0]=1,sgn=0 ;}else if(!sgn)sgn=-SGN(a),add(num,ABS(a));return*this ;}inline bignum operator-(const bignum&a){bignum ret ;memcpy(ret.num,num,sizeof(bignum_t));ret.sgn=sgn ;ret-=a ;return ret ;}inline bignum operator-(const int a){bignum ret ;memcpy(ret.num,num,sizeof(bignum_t));ret.sgn=sgn ;ret-=a ;return ret ;}inline bignum&operator*=(const bignum&a){bignum_t t ;mul(t,num,a.num);memcpy(num,t,sizeof(bignum_t));sgn*=a.sgn ;return*this ;}inline bignum&operator*=(const int a){mul(num,ABS(a));sgn*=SGN(a);return*this ;}inline bignum operator*(const bignum&a){bignum ret ;mul(ret.num,num,a.num);ret.sgn=sgn*a.sgn ;return ret ;}inline bignum operator*(const int a){bignum ret ;memcpy(ret.num,num,sizeof (bignum_t));mul(ret.num,ABS(a));ret.sgn=sgn*SGN(a);return ret ;}inline bignum&operator/=(const bignum&a){bignum_t t ;div(t,num,a.num);memcpy (num,t,sizeof(bignum_t));sgn=(num[0]==1&&!num[1])?0:sgn*a.sgn ;return*this ;}inline bignum&operator/=(const int a){int t ;div(num,ABS(a),t);sgn=(num[0]==1&&!num [1])?0:sgn*SGN(a);return*this ;}inline bignum operator/(const bignum&a){bignum ret ;bignum_t t ;memcpy(t,num,sizeof(bignum_t));div(ret.num,t,a.num);ret.sgn=(ret.num[0]==1&&!ret.num[1])?0:sgn*a.sgn ;return ret ;}inline bignum operator/(const int a){bignum ret ;int t ;memcpy(ret.num,num,sizeof(bignum_t));div(ret.num,ABS(a),t);ret.sgn=(ret.num[0]==1&&!ret.num[1])?0:sgn*SGN(a);return ret ;}inline bignum&operator%=(const bignum&a){bignum_t t ;div(t,num,a.num);if(num[0]==1&&!num[1])sgn=0 ;return*this ;}inline int operator%=(const int a){int t ;div(num,ABS(a),t);memset(num,0,sizeof (bignum_t));num[0]=1 ;add(num,t);return t ;}inline bignum operator%(const bignum&a){bignum ret ;bignum_t t ;memcpy(ret.num,num,sizeof(bignum_t));div(t,ret.num,a.num);ret.sgn=(ret.num[0]==1&&!ret.num [1])?0:sgn ;return ret ;}inline int operator%(const int a){bignum ret ;int t ;memcpy(ret.num,num,sizeof(bignum_t));div(ret.num,ABS(a),t);memset(ret.num,0,sizeof(bignum_t));ret.num[0]=1 ;add(ret.num,t);return t ;}inline bignum&operator++(){*this+=1 ;return*this ;}inline bignum&operator--(){*this-=1 ;return*this ;};inline int operator>(const bignum&a){return sgn>0?(a.sgn>0?comp(num,a.num)>0:1):(sgn<0?(a.sgn<0?comp(num,a.num)<0:0):a.sgn<0);}inline int operator>(const int a){return sgn>0?(a>0?comp(num,a)>0:1):(sgn<0?(a<0?comp(num,-a)<0:0):a<0);}inline int operator>=(const bignum&a){return sgn>0?(a.sgn>0?comp(num,a.num)>=0:1):(sgn<0?(a.sgn<0?comp(num,a.num)<=0:0):a.sgn<=0);}inline int operator>=(const int a){return sgn>0?(a>0?comp(num,a)>=0:1):(sgn<0?(a<0?comp(num,-a)<=0:0):a<=0);}inline int operator<(const bignum&a){return sgn<0?(a.sgn<0?comp(num,a.num)>0:1):(sgn>0?(a.sgn>0?comp(num,a.num)<0:0):a.sgn>0);}inline int operator<(const int a){return sgn<0?(a<0?comp(num,-a)>0:1):(sgn>0?(a>0?comp(num,a)<0:0):a>0);}inline int operator<=(const bignum&a){return sgn<0?(a.sgn<0?comp(num,a.num)>=0:1):(sgn>0?(a.sgn>0?comp(num,a.num)<=0:0):a.sgn>=0);}inline int operator<=(const int a){return sgn<0?(a<0?comp(num,-a)>=0:1):(sgn>0?(a>0?comp(num,a)<=0:0):a>=0);}inline int operator==(const bignum&a){return(sgn==a.sgn)?!comp(num,a.num):0 ;}inline int operator==(const int a){return(sgn*a>=0)?!comp(num,ABS(a)):0 ;}inline int operator!=(const bignum&a){return(sgn==a.sgn)?comp(num,a.num):1 ;}inline int operator!=(const int a){return(sgn*a>=0)?comp(num,ABS(a)):1 ;}inline int operator[](const int a){return digit(num,a);}friend inline istream&operator>>(istream&is,bignum&a){read(a.num,a.sgn,is);return is ;}friend inline ostream&operator<<(ostream&os,const bignum&a){if(a.sgn<0)os<<'-' ;write(a.num,os);return os ;}friend inline bignum sqrt(const bignum&a){bignum ret ;bignum_t t ;memcpy(t,a.num,sizeof(bignum_t));sqrt(ret.num,t);ret.sgn=ret.num[0]!=1||ret.num[1];return ret ;}friend inline bignum sqrt(const bignum&a,bignum&b){bignum ret ;memcpy(b.num,a.num,sizeof(bignum_t));sqrt(ret.num,b.num);ret.sgn=ret.num[0]!=1||ret.num[1];b.sgn=b.num[0]!=1||ret.num[1];return ret ;}inline int length(){return :: length(num);}inline int zeronum(){return :: zeronum(num);}inline bignum C(const int m,const int n){combination(num,m,n);sgn=1 ;return*this ;}inline bignum P(const int m,const int n){permutation(num,m,n);sgn=1 ;return*this ;} };/*int main(){bignum a,b,c;cin>>a>>b;cout<<"加法:"<<a+b<<endl;cout<<"減法:"<<a-b<<endl;cout<<"乘法:"<<a*b<<endl;cout<<"除法:"<<a/b<<endl;c=sqrt(a);cout<<"平方根:"<<c<<endl;cout<<"a的長度:"<<a.length()<<endl;cout<<"a的末尾0個數:"<<a.zeronum()<<endl<<endl;cout<<"組合: 從10個不同元素取3個元素組合的所有可能性為"<<c.C(10,3)<<endl;cout<<"排列: 從10個不同元素取3個元素排列的所有可能性為"<<c.P(10,3)<<endl;return 0 ;}*/int main(int argc, const char * argv[]) {bignum a;while(cin>>a){int cnt=0;int flag=0;bignum b;b = 1;//cout<<b<<endl;//b += 1;while(a != b){a = sqrt(a);//cout<<a<<endl;cnt++;if(cnt>5){flag = 1;break;}}if(flag == 0) printf("%d\n",cnt);else printf("TAT\n");}return 0; } View Code

?

B -?Permutation Bo

這題主要根據期望的可加性,將總的期望轉變為求每一個位置的期望和。

然后推下公式就可以發現在最左邊和最右邊概率為(1/2)

在其他位置的為(1/3). 還得注意n==1 的特殊情況。

// // main.cpp // multi2016.3.B // // Created by New_Life on 16/8/1. // Copyright ? 2016年 chenhuan001. All rights reserved. // #include <iostream> #include <stdio.h> #include <string.h> #include <algorithm> using namespace std;int main(int argc, const char * argv[]) {int n;while(cin>>n){double ans = 0;for(int i=1;i<=n;i++){int tmp;scanf("%d",&tmp);if(i==1 || i==n) ans += (0.5)*tmp;else ans += (1.0/3.0)*tmp;}if(n==1){ans *= 2;}printf("%.6lf\n",ans);}return 0; } View Code

?

C -?Life Winner Bo

不得不說這題就是個代碼量稍微大一點的模擬題。

但是看了大家的題解后發現,怪不得大家做出來的這么多,原來直接用幾種經典的博弈可以直接算出來,仔細一想確實把三種經典博弈全部都用上了。

我用的dp的方法,對于king 和 knight 直接dp搞就行了。

對于車和皇后,則則需要用額外的數組紀錄下。

// // main.cpp // multi2016.3.J // // Created by New_Life on 16/8/1. // Copyright ? 2016年 chenhuan001. All rights reserved. // #include <iostream> #include <string.h> #include <stdio.h> #include <math.h> #include <algorithm> using namespace std;int mark[1002][1002][4]; int save[1002][1002][3];//三個方向//處理king和kinght int dfs(int x,int y,int type) {if(mark[x][y][type] != -1) return mark[x][y][type];int flag = 0;int flag2 = 0;if(type == 0){if(x+1<=1000 && dfs(x+1,y,type)==0) flag=1;if(y+1<=1000 && dfs(x,y+1,type)==0) flag=1;if(x+1<=1000 && y+1<=1000 && dfs(x+1,y+1,type)==0) flag=1;return mark[x][y][type]=flag;}else //只有這里會存在。。。平局 {flag = -1;if(x+2<=1000 && y+1<=1000){if(dfs(x+2,y+1,type) == 0){flag = 1;}else if(dfs(x+2,y+1,type) == 2) flag2= 1;else flag = 0;}if(y+2<=1000 && x+1<=1000){if(dfs(x+1,y+2,type)==0) flag = 1;else if(dfs(x+1,y+2,type)==2) flag2 =1;else flag = 0;}if(flag == 1) return mark[x][y][type] = 1;//能必勝else if(flag2 == 1 || flag == -1) return mark[x][y][type] = 2;else{return mark[x][y][type] = 0;}} }int main() {memset(mark,-1,sizeof(mark));for(int i=0;i<4;i++)mark[1000][1000][i] = 0;for(int i=1;i<=1000;i++)for(int j=1;j<=1000;j++)for(int k=0;k<2;k++){dfs(i,j,k);}//然后來搞車int x[1002],y[1002];memset(x, 0, sizeof(x));memset(y, 0, sizeof(y));for(int i=1000;i>=1;i--)for(int j=1000;j>=1;j--){int flag = 0;if( x[i]==1 || y[j]==1 ) flag = 1;mark[i][j][2] = flag;if(flag == 0){x[i] = 1;y[j] = 1;}}//這里還是錯了for(int i=1000;i>=1;i--)for(int j=1000;j>=1;j--){int flag=0;if(i+1<=1000 && save[i+1][j][0]==1) flag = 1;if(j+1<=1000 && save[i][j+1][1]==1) flag = 1;if(i+1<=1000 && j+1<=1000 && save[i+1][j+1][2]==1) flag = 1;mark[i][j][3] = flag;if(flag == 0){save[i][j][0] = 1;save[i][j][1] = 1;save[i][j][2] = 1;}else{save[i][j][0] = save[i+1][j][0];save[i][j][1] = save[i][j+1][1];save[i][j][2] = save[i+1][j+1][2];}}int T;cin>>T;while(T--){int type,n,m;cin>>type>>n>>m;if(type == 1) type = 0;if(type == 2) type = 2;if(type == 3) type = 1;if(type == 4) type = 3;int flag = mark[1000-n+1][1000-m+1][type];if(flag == 0) printf("G");else if(flag == 1) printf("B");else printf("D");printf("\n");}return 0; }/*101 5 52 5 53 5 54 5 53 2 23 2 33 3 5ans:GGDBDBD */ View Code

?

D -?Gambler Bo

用構造,二分圖,dp什么的鬼想法想了一下午。 后面看題解發現是高斯消元裸題,簡直要撞墻。。。 md taicaile

如果用高斯消元的方法就很好想了。

不過這題還是個線性同余方程組。

具體參見。

?

?G -?Explorer Bo

首先這題確定的最小的移動次數。

稍作分析可以發現,當葉節點個數為偶數時,移動次數必為 (葉節點總數/2)

當葉節點個數為奇數時,移動次數比為(葉節點總數+1)/2

對于偶數的情況,很好分析。 對于每一條樹邊,如果兩側的葉節點個數都為偶數,那么這條樹邊必會走兩次,否則只需要走一次。這樣一趟 dfs 就可以搞定

對于奇數的情況,則需要唯一確定一條不用兩端都為葉節點的路徑。用樹形dp和線段樹都可以解決。 我用的線段樹.

// // main.cpp // hdu5758 // // Created by New_Life on 16/8/3. // Copyright &#169; 2016年 chenhuan001. All rights reserved. // #include <iostream> #include <string.h> #include <stdio.h> #include <algorithm> using namespace std; #define N 100100int n; struct node{int to,next; }edge[2*N];int cnt,pre[N]; int leafid; int savel[N],saver[N]; int ans;void add_edge(int u,int v) {edge[cnt].to = v;edge[cnt].next = pre[u];pre[u] = cnt++; }void dfs(int s,int fa,int first) {int flag = 0;//是否是葉子結點int saveid = leafid;for(int p = pre[s];p!=-1;p=edge[p].next){int v = edge[p].to;if(v == fa) continue;flag ++;dfs(v,s,0);}if(first == 1){if(flag == 1)//is leaf {leafid++;}}elseif(flag == 0){leafid++;}savel[s] = saveid+1;saver[s] = leafid; }void dfs1(int s,int fa) {for(int p=pre[s];p!=-1;p=edge[p].next){int v = edge[p].to;if(v == fa) continue;int x1 = saver[v]-savel[v]+1;//int x2 = leafid - x1;ans += (2-x1%2);dfs1(v,s);} }#define max(a,b) (a>b)?a:b #define min(a,b) (a>b)?b:a #define lson l , m , rt << 1 #define rson m + 1 , r , rt << 1 | 1#define LL long longconst int maxn = N; LL lazy[maxn<<2]; LL sum[maxn<<2];void putup(int rt) {sum[rt] = sum[rt<<1] + sum[rt<<1|1]; } void putdown(int rt,int m) {if (lazy[rt]){lazy[rt<<1] += lazy[rt];lazy[rt<<1|1] += lazy[rt];sum[rt<<1] += lazy[rt] * (m - (m >> 1));sum[rt<<1|1] += lazy[rt] * (m >> 1);lazy[rt] = 0;} } void build(int l,int r,int rt) {lazy[rt] = 0;if (l == r){sum[rt] = 0;//scanf("%I64d",&sum[rt]);return ;}int m = (l + r) >> 1;build(lson);build(rson);putup(rt); } void update(int L,int R,int c,int l,int r,int rt) {if (L <= l && r <= R){lazy[rt] += c;sum[rt] += (LL)c * (r - l + 1);return ;}putdown(rt , r - l + 1);int m = (l + r) >> 1;if (L <= m) update(L , R , c , lson);if (m < R) update(L , R , c , rson);putup(rt); } LL query(int L,int R,int l,int r,int rt) {if (L <= l && r <= R){return sum[rt];}putdown(rt , r - l + 1);int m = (l + r) >> 1;LL ret = 0;if (L <= m) ret += query(L , R , lson);if (m < R) ret += query(L , R , rson);return ret; } /*int main(){int n , m;int a , b , c;char str[5];scanf("%d%d",&n,&m);build(1 , n , 1);while (m--){scanf("%s",str);if (str[0] == 'Q'){scanf("%d%d",&a,&b);printf("%I64d\n",query(a , b , 1 , n , 1));}else if(str[0]=='C'){scanf("%d%d%d",&a,&b,&c);update(a , b , c , 1 , n , 1);}}return 0;}*/void dfs2(int s,int fa) {for(int p=pre[s];p!=-1;p=edge[p].next){int v = edge[p].to;if(v == fa) continue;int x1 = saver[v]-savel[v]+1;int x2 = leafid - x1;int tmp1=0,tmp2=0;x1--;if(x1!=0) tmp1 = (2-x1%2);else tmp1 = 1;x1 ++;x2--;if(x2!=0) tmp2 = (2-x2%2);else tmp2 = 1;x2++;update(1,leafid,tmp2,1,leafid,1);update(savel[v],saver[v],tmp1-tmp2,1,leafid,1);dfs2(v,s);} }int main(int argc, const char * argv[]) {int T;cin>>T;while(T--){cin>>n;cnt = 0;memset(pre,-1,sizeof(pre));for(int i=1;i<n;i++){int x,y;scanf("%d%d",&x,&y);add_edge(x,y);add_edge(y,x);}if(n == 1){printf("0\n");continue;}leafid = 0;dfs(1, -1, 1);//第一遍建立線段區間,且得出有多少葉節點. ans = 0;if(leafid%2 == 0)//葉節點為偶數 {//一趟dfs搞定dfs1(1, -1);}else{build(1, leafid, 1);dfs2(1,-1);ans = 1000000000;for(int i=1;i<=leafid;i++){ans = min(ans,(int)query(i, i, 1, leafid, 1));}}printf("%d\n",ans);}return 0; } /*1041 22 33 451 55 22 32 491 22 32 43 53 64 77 87 9*/ View Code

?

J -?Rower Bo

應該是高中的物理競賽會考的東西。

這種巧妙的公式,沒做過的人好難。 聽說很多人都是直接猜的公式,這場比賽3題都可以找規律。 orz

?

K -?Teacher Bo

因為n*m的圖的曼哈頓距離最多有2*(n+m)種,所以當n>500 時必有相同點,n<500直接暴力。

// // main.cpp // multi2016.3.B // // Created by New_Life on 16/8/1. // Copyright ? 2016年 chenhuan001. All rights reserved. // #include <iostream> #include <stdio.h> #include <string.h> #include <math.h> #include <algorithm> using namespace std;struct point {int x,y; }g[100100];int mark[200200];//僅適合純數字輸入 int Scan() //輸入外掛 {int res=0,ch,flag=0;if((ch=getchar())=='-')flag=1;else if(ch>='0'&&ch<='9')res=ch-'0';while((ch=getchar())>='0'&&ch<='9')res=res*10+ch-'0';return flag?-res:res; } void Out(int a) //輸出外掛 {if(a>9)Out(a/10);putchar(a%10+'0'); }int main(int argc, const char * argv[]) {int T;cin>>T;while(T--){int n,m;scanf("%d%d",&n,&m);for(int i=0;i<n;i++){g[i].x = Scan();g[i].y = Scan();}if(n>500) printf("YES\n");else{memset(mark,0,sizeof(mark));//for(int i=0;i<2*m;i++)int flag=0;for(int i=0;i<n;i++){if(flag) break;for(int j=i+1;j<n;j++){int tmp = abs(g[i].x-g[j].x)+abs(g[i].y-g[j].y);mark[ tmp ]++;if(mark[tmp] >= 2){flag = 1;break;}}}if(flag) printf("YES\n");else printf("NO\n");}}return 0; } View Code

?

總結

以上是生活随笔為你收集整理的2016 Multi-University Training Contest 3的全部內容,希望文章能夠幫你解決所遇到的問題。

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

日韩亚洲国产中文字幕 | 在线观看一区二区精品 | 欧美日韩在线看 | 超碰个人在线 | 草久视频在线 | 免费a视频在线 | 亚洲激情 | 欧美日韩一级久久久久久免费看 | 国产高清视频 | 国产视频69| 日韩在线视频国产 | 91中文字幕在线观看 | 欧美aaaxxxx做受视频 | 精品视频123区在线观看 | 国产精品青草综合久久久久99 | 天天综合视频在线观看 | 在线高清一区 | 亚洲精品国产日韩 | 成人高清在线 | 精品福利在线视频 | 午夜精品影院 | 亚洲视频在线免费看 | 欧美成人精品xxx | 嫩草伊人久久精品少妇av | 日韩在线观看中文 | 在线看中文字幕 | 久久艹综合 | 国产精品丝袜 | 免费黄色在线 | 97免费公开视频 | 久久精品视频免费播放 | 在线 欧美 日韩 | 美国av片在线观看 | 狠狠狠狠狠色综合 | 精品毛片一区二区免费看 | 久久国内精品99久久6app | 精品久久91 | 国产精品美女免费 | 热99久久精品 | 国产精品欧美日韩在线观看 | 免费三级av | 亚洲精品白浆高清久久久久久 | 黄色软件视频网站 | 久久人人爽视频 | 精品 一区 在线 | 五月婷婷六月丁香 | 亚洲开心色 | 在线观看国产永久免费视频 | 黄色av影院 | 国产日韩视频在线观看 | 黄色app网站在线观看 | 日韩精品大片 | 99久久精品免费看国产四区 | 天天天干天天射天天天操 | 蜜桃视频成人在线观看 | 色婷婷狠狠五月综合天色拍 | 久久精品国产免费观看 | aaa毛片视频 | 亚洲最大成人免费网站 | 永久av免费在线观看 | av在线网站免费观看 | 免费成人在线观看视频 | 欧美日韩一区二区三区免费视频 | 干天天 | 色99网| 国产高清视频色在线www | 亚洲精品动漫成人3d无尽在线 | 在线免费观看国产 | 精品久久91| 黄色av免费 | 一区二区 不卡 | 91免费高清观看 | 性色av香蕉一区二区 | 午夜精品剧场 | 国产精品中文字幕在线播放 | 久久免费播放 | 一区二区三区日韩在线观看 | 欧美一级视频免费 | 天天爽天天爽天天爽 | 黄在线免费观看 | 天天爽天天爽天天爽 | av网站地址 | 国产成人免费精品 | 黄色软件在线观看免费 | 中文字幕免费一区二区 | 成人久久久久久久久 | 久久最新视频 | 深爱激情综合网 | 色婷婷综合久久久久中文字幕1 | 在线一级片 | 手机在线永久免费观看av片 | 色中色综合 | 四虎永久免费在线观看 | 色窝资源 | 国产精品视频99 | 亚洲国产精品久久久久婷婷884 | 日日添夜夜添 | 国产激情免费 | 午夜国产福利在线 | 国产成人综合精品 | 国产91精品看黄网站 | 国产精品久久久久9999吃药 | v片在线播放 | 国产精品成人久久久 | 国产精品18久久久久vr手机版特色 | 9在线观看免费高清完整版在线观看明 | 久久久99国产精品免费 | 久久久久免费电影 | 天天操天天艹 | 国产精品com| 噜噜色官网 | 国产激情小视频在线观看 | 又爽又黄又无遮挡网站动态图 | www.91av在线 | 午夜视频在线网站 | 亚洲精品乱码久久久一二三 | 在线观看免费版高清版 | 91精品久久香蕉国产线看观看 | 国产亚洲视频在线 | 精品免费久久久久久 | 亚洲天天做 | 狠狠色噜噜狠狠 | 日韩大片免费观看 | 91视频在线免费下载 | 在线播放 日韩专区 | www.久草视频 | 亚洲 欧美日韩 国产 中文 | 久久美女精品 | 久久er99热精品一区二区三区 | 久久第四色| av免费电影在线观看 | 国产无遮挡又黄又爽馒头漫画 | 成人久久久精品国产乱码一区二区 | 日韩av伦理片 | 久草视频精品 | 日韩激情一二三区 | 精品欧美在线视频 | 成人免费色 | 成人久久18免费网站 | 99热精品在线 | 成人禁用看黄a在线 | 亚洲欧美视频在线观看 | 久久国产精品一区二区三区四区 | 99色 | 精品国产一区二区三区久久影院 | 91精品国产一区二区三区 | 在线免费观看黄色大片 | 啪啪精品| 国产一卡二卡四卡国 | 欧美综合久久久 | 久久久久久久av麻豆果冻 | 六月激情网 | 天天色天天色天天色 | 国产女人40精品一区毛片视频 | 又黄又爽的视频在线观看网站 | 久久综合五月天婷婷伊人 | 国产精品久久片 | 精品伊人久久久 | 久久精品之 | 丁香九月婷婷综合 | 国产99久久九九精品免费 | 亚洲午夜小视频 | 日三级在线 | 中文字幕在线观看视频免费 | 人人插人人做 | 免费在线观看黄色网 | 国产最顶级的黄色片在线免费观看 | 亚洲 精品在线视频 | 黄色三级在线看 | 园产精品久久久久久久7电影 | 福利精品在线 | 久久久免费 | 日韩高清不卡一区二区三区 | 国产黄色免费看 | 亚洲午夜精品久久久久久久久久久久 | 免费观看91视频大全 | 在线观看成人网 | 福利一区视频 | 精精国产xxxx视频在线播放 | 精品国产自 | 欧美精品久久久久久久久久 | 美女免费视频观看网站 | 特级毛片在线 | 18av在线视频 | 17videosex性欧美| 久亚洲精品 | 日韩av在线小说 | 天天操网站 | 97色在线观看 | 欧美在线观看视频一区二区 | 色资源网在线观看 | 亚洲伊人色 | 91九色免费视频 | 91日韩在线视频 | 五月天婷亚洲天综合网鲁鲁鲁 | 日本资源中文字幕在线 | 国产精品一区免费在线观看 | 人人爽人人av | 在线观看网站你懂的 | 中文字幕日本在线观看 | 欧美日高清视频 | 国产视频在线观看免费 | avav99| 成人蜜桃网 | 狠狠久久伊人 | 91精品国自产在线观看欧美 | 九月婷婷综合网 | 亚洲黄色大片 | 91福利专区| 精品国产一区二区三区免费 | 国产精品对白一区二区三区 | 黄在线免费看 | 国产精品欧美一区二区 | www.夜夜爱 | 国产1区2区 | 久久怡红院 | 在线观看国产www | 成人网页在线免费观看 | a视频免费| av成人黄色| 国产成人一级 | 人人澡人人草 | 久久9999久久| 久久a国产 | 粉嫩av一区二区三区四区五区 | 91香蕉视频好色先生 | 日韩一二区在线观看 | 国产视频999| 91av小视频| 婷婷色中文字幕 | 91成人破解版 | 久久国产精品网站 | 一本—道久久a久久精品蜜桃 | 2021国产在线视频 | 九九在线精品视频 | 久久精品视频在线 | 天天天天色射综合 | 日日日爽爽爽 | 九九视频精品在线 | 99精品观看 | 91超国产 | 日韩,中文字幕 | 91中文视频 | 97电院网手机版 | 中文国产成人精品久久一 | 美女免费视频一区二区 | 超碰97公开 | 在线视频免费观看 | 亚洲国产精品500在线观看 | 久久久久久国产精品久久 | 国产成人精品av在线 | av日韩精品 | 五月婷婷六月丁香 | 亚洲精品在线电影 | av在线免费网| 丁香六月天婷婷 | 高清av免费一区中文字幕 | 狠狠色狠狠综合久久 | 免费视频黄色 | 一级黄色电影网站 | 久要激情网| 中文字幕免费看 | 欧美大片大全 | 五月亚洲综合 | 日产中文字幕 | 人人cao| 色五月成人 | 果冻av在线 | 亚洲精品视频在线观看网站 | 中国一级片在线播放 | 中文字幕第一页在线vr | 中文字幕黄色av | 欧美日韩性生活 | 日韩大片在线免费观看 | 国产在线一线 | 精品1区2区 | 欧美色综合久久 | 日本视频不卡 | 91av片| 999国产在线 | 成人91免费视频 | 十八岁免进欧美 | 久久精精品| 久久精品视频免费 | 成人免费在线网 | 草久在线观看 | 欧美亚洲三级 | 狠狠干夜夜 | 中文区中文字幕免费看 | 激情综合色综合久久综合 | 国产 字幕 制服 中文 在线 | 成年人app网址 | 激情网站免费观看 | 亚洲成人频道 | 久久国产亚洲视频 | 亚洲最大在线视频 | 日韩精品在线观看视频 | 国产黄影院色大全免费 | 日韩和的一区二在线 | 久久不射电影院 | 欧美有色 | 亚洲一级国产 | 九九视频网 | 日韩精品无 | 99色亚洲 | 在线看的av网站 | 欧美日韩高清一区二区 国产亚洲免费看 | 国产五月婷婷 | 日韩久久一区 | 天堂中文在线视频 | 99久在线精品99re8热视频 | 99在线视频精品 | 激情五月六月婷婷 | 中国黄色一级大片 | 96超碰在线 | 91人人在线 | 国产日韩欧美自拍 | 国产91在线观| 热久久在线视频 | 国产一级免费观看视频 | 国产精品免费在线观看视频 | 久久久久亚洲国产精品 | 黄色大片日本免费大片 | 欧美激情视频久久 | 91成熟丰满女人少妇 | 一区二区精品在线 | 91超在线| 成人影片在线免费观看 | 婷婷伊人综合 | 成人av高清 | 一区二区三区在线免费观看 | 中文字幕视频三区 | 91中文字幕在线播放 | 人人爱爱人人 | 在线观看免费色 | 丝袜制服天堂 | 亚洲伊人色 | 99久久精品无免国产免费 | 啪啪激情网 | 精品视频在线免费 | 久久久久伦理电影 | 国产美腿白丝袜足在线av | 91香蕉视频好色先生 | 欧美日韩在线电影 | 成人a在线 | 国产精品小视频网站 | 国产精品美乳一区二区免费 | 日本中文字幕在线视频 | 激情av一区二区 | freejavvideo日本免费 | 右手影院亚洲欧美 | 正在播放一区 | 久久精品79国产精品 | 在线观看中文字幕一区 | 久久全国免费视频 | 国产中文字幕视频 | 久久久久久综合网天天 | 国产精品99久久久久的智能播放 | 黄色一级免费电影 | 国内久久久久久 | 五月婷在线视频 | 国产一区网址 | 天堂av在线 | 日韩一级理论片 | 亚洲天天草 | 在线电影a | 成人av一级片 | 久久婷婷色综合 | 中文字幕三区 | 成人试看120秒 | 亚洲国产成人精品电影在线观看 | 国产一级一级国产 | 欧美91av| 国产精品免费观看久久 | 夜夜操网站| 五月婷婷欧美 | 九七在线视频 | 亚州国产精品视频 | 麻豆影视在线播放 | 亚洲视频aaa | 色插综合| 高清av在线| 青青看片 | 日韩久久精品一区二区三区下载 | 欧美激情综合五月色丁香小说 | 狠狠躁夜夜躁人人爽超碰97香蕉 | 日韩午夜精品福利 | av色一区 | av久久在线 | 中文字幕久久精品亚洲乱码 | 美女久久久久久久久久久 | 狠狠色丁香婷婷综合久小说久 | 三级av免费看 | 91中文字幕在线 | 黄色中文字幕在线 | 亚洲精品国产精品久久99热 | 亚洲精品1区2区3区 超碰成人网 | www.久久免费视频 | 中文久草 | 日本精品久久久久 | 欧美日韩在线观看一区二区三区 | 欧美色操| 久久久精品久久日韩一区综合 | 青青河边草免费视频 | 国产一区免费视频 | 激情综合中文娱乐网 | 手机看国产毛片 | 激情五月婷婷综合网 | 国产伦精品一区二区三区在线 | 亚洲综合在 | 久久99精品久久只有精品 | av观看在线观看 | 92中文资源在线 | 一区二区av | 亚洲成人av在线播放 | 免费福利在线视频 | 手机在线永久免费观看av片 | 国产精品久久电影观看 | av中文国产| 精品一区二区视频 | www.av在线.com| 在线观看黄色的网站 | 精品国产视频在线 | a级片在线播放 | 在线观看爱爱视频 | 精品在线观 | 色av色av色av | 天堂激情网| 亚洲精品456在线播放乱码 | 一区二区三区四区五区在线 | 97人人看 | 天天干天天操天天干 | 国产精品网站一区二区三区 | 日韩电影在线观看一区 | 综合五月| 黄色片网站免费 | 久久99国产精品视频 | 色婷婷在线视频 | 久久精品视频在线免费观看 | 日韩欧美在线免费观看 | 玖玖玖影院| 玖玖综合网 | 麻豆91精品 | 丁香六月婷婷激情 | 免费在线精品视频 | 国产精品女同一区二区三区久久夜 | 91九色精品 | 中文字幕免费播放 | 粉嫩av一区二区三区四区在线观看 | 国产一级黄色av | 九九热视频在线播放 | 久久久久久久亚洲精品 | 最近中文字幕在线 | 久人人 | 国产在线观看你懂的 | 久久国产网站 | 日韩av成人免费看 | 欧美一区二区在线免费观看 | 日韩在线大片 | 国产18精品乱码免费看 | 色综合久久久久综合体桃花网 | 午夜av一区二区三区 | 国产视频一区在线免费观看 | 日韩区视频 | 久久精品中文 | 射久久久 | 碰超在线 | 日本精品久久久久 | 国产精品一区免费在线观看 | 免费观看av网站 | 久久精品导航 | 日日夜夜综合 | 免费在线观看黄 | 欧美一区二区三区在线播放 | wwwwww黄| 精品国产视频在线 | 国产黄色理论片 | 欧美日韩国产一二三区 | 91人人澡人人爽 | 国产精品第一页在线 | 人人爽人人爽 | 国产精品乱码一区二区视频 | 中文av一区二区 | 亚洲免费婷婷 | 热精品| 激情视频一区二区三区 | 婷婷免费在线视频 | 日日夜夜综合网 | 中文字幕av有码 | 亚洲一级电影 | 国产精品涩涩屋www在线观看 | 国产日韩欧美视频在线观看 | 日日夜夜精品免费 | 欧美精品亚洲二区 | 亚洲精品综合一二三区在线观看 | 西西444www大胆高清视频 | 免费在线观看毛片网站 | 久久综合干 | 免费人成在线观看 | 999成人| 美女网站免费福利视频 | 天天干天天干天天干 | 天堂av免费在线 | 中文字幕 国产视频 | 午夜精品麻豆 | 丝袜网站在线观看 | 国产电影黄色av | 午夜国产一区二区 | 91x色| 亚洲第一中文字幕 | 国产一级久久 | 免费午夜av | 最近中文字幕免费视频 | 精品人人人 | 国产精品久久久久久妇 | 米奇影视7777 | 91av网站在线观看 | 亚洲午夜久久久影院 | 在线视频欧美日韩 | 99热手机在线 | 久久伦理网 | 国内99视频| 免费在线观看av网址 | 亚洲高清国产视频 | 国产免费影院 | 国产aa精品 | 亚洲成人精品久久久 | 精品福利av | 亚洲小视频在线观看 | 国产99在线 | 免费黄a| 在线观看国产福利片 | 久草免费在线视频 | av在线免费网站 | 亚洲毛片在线观看. | 激情自拍av | 在线观看中文字幕av | av不卡中文 | 91香蕉亚洲精品 | 国产精品 日韩精品 | 日韩大片在线看 | 色综合五月天 | 五月婷婷丁香综合 | 国产婷婷一区二区 | 欧美人体xx | 日本久久高清视频 | 免费v片| 欧美极度另类 | 精品国产一区二区三区久久久久久 | 伊人av综合| 日韩欧美aaa | 日韩在线视频网站 | 免费看91的网站 | 日本中文字幕在线视频 | 午夜精品一区二区三区视频免费看 | 国产精选视频 | 狠狠做六月爱婷婷综合aⅴ 日本高清免费中文字幕 | 天天操操操操操操 | 国产精品午夜在线 | 亚洲综合网站在线观看 | 久久理论电影 | 欧美成人xxxxx | 欧美最新另类人妖 | 黄色三级网站在线观看 | 久久久久久久久久久黄色 | 国产精品 中文在线 | 免费网站在线 | 中文字幕在线看视频 | 99在线播放 | 亚洲精品视频网站在线观看 | 国产精品 美女 | 中文字幕有码在线播放 | 日本精品一区二区三区在线观看 | 在线v片 | 国产视频综合在线 | 国产精品成人自产拍在线观看 | 久久人人爽人人爽人人片 | 欧美一区三区四区 | 99精品观看| 午夜在线看片 | 国产高清无线码2021 | a级国产乱理论片在线观看 特级毛片在线观看 | 欧美 高跟鞋交 xxxxhd | 毛片网站免费在线观看 | 欧美福利网址 | 免费在线视频一区二区 | 黄色精品久久 | 国产亚洲日 | 丁香婷婷色月天 | 久亚洲| 99久久婷婷国产一区二区三区 | 国产一线二线三线在线观看 | 1024手机基地在线观看 | 91在线播放视频 | 精品亚洲在线 | 国产精品麻豆三级一区视频 | 成人免费亚洲 | 日韩免费一区二区在线观看 | 香蕉久久久久久久 | 久久少妇av | 国产精品igao视频网网址 | 国产福利一区在线观看 | 亚洲区另类春色综合小说校园片 | 99久久久国产精品美女 | 国产专区精品视频 | 精品国产乱码久久久久 | 久久婷婷一区二区三区 | 婷婷福利影院 | 久久久久久免费视频 | 国产成人一区二区三区在线观看 | 久久一区二区三区国产精品 | 五月婷婷毛片 | 国产一级视屏 | 亚洲精品白浆高清久久久久久 | 亚洲美女视频网 | 在线视频中文字幕一区 | 91精品在线视频 | 精品一区二区精品 | 色欧美日韩 | 国产高清免费在线播放 | 国产麻豆精品免费视频 | 国产精品精品国产婷婷这里av | av在线播放中文字幕 | 四虎成人精品在永久免费 | 日韩欧美电影 | 中文字幕一区二区三区久久蜜桃 | 日韩欧美视频免费看 | 久久婷婷亚洲 | 成人黄色影片在线 | 99久久久久久久久 | 日韩在线观看一区二区 | 久在线| 狠狠操狠狠干天天操 | 91一区二区三区久久久久国产乱 | 国产丝袜制服在线 | 青草视频在线 | 中文字幕无吗 | 日韩久久精品一区二区三区下载 | 欧美激情第28页 | 天天操天天拍 | 日本夜夜草视频网站 | 国产精品久久久久久久7电影 | 500部大龄熟乱视频使用方法 | 手机av片 | 日日干天天射 | 在线黄色国产电影 | 欧美久久久久久久久 | 国产精品美女视频网站 | 狠狠操狠狠干天天操 | 亚洲欧美在线综合 | 日韩免费在线观看视频 | 亚洲韩国一区二区三区 | 亚洲黄网址 | 韩国一区在线 | 免费成人av | 激情综合网色播五月 | 国产黄色免费电影 | av福利在线免费观看 | 欧美人交a欧美精品 | 激情图片久久 | 看片在线亚洲 | 夜夜嗨av色一区二区不卡 | 免费亚洲视频 | 狠狠色丁香久久婷婷综合丁香 | 二区在线播放 | 国产精品久久久久久久久免费看 | 国产精品成人av电影 | 色综合久久中文字幕综合网 | 国产精品一区二区精品视频免费看 | 丁香五月亚洲综合在线 | 免费亚洲一区二区 | 欧美日韩久| 国产精品一区二区三区电影 | 亚洲影院色 | 亚洲特级片 | 欧美在线视频a | 亚州中文av | av 在线观看 | 香蕉色综合 | 97av.com| 日韩精品一区二区三区中文字幕 | 免费看的黄色的网站 | 婷婷射五月 | 日本韩国精品一区二区在线观看 | 99中文字幕在线观看 | 综合亚洲视频 | 欧美另类69 | 久久精品久久久久电影 | 激情综合五月天 | 丝袜美腿在线视频 | 午夜婷婷综合 | 久久中国精品 | 手机av资源 | 成人小视频在线 | 在线免费黄色 | 久久这里只有精品视频99 | 日韩欧美视频一区二区 | 成 人 免费 黄 色 视频 | 一区二区欧美日韩 | 成人v| 在线看片一区 | 亚洲午夜久久久久久久久 | 日韩欧美一区二区不卡 | 国产一区欧美二区 | 91久久人澡人人添人人爽欧美 | 在线观看免费成人 | 亚洲清纯国产 | 久久免费在线视频 | av 一区二区三区 | 中文在线最新版天堂 | 香蕉视频色 | 国产成人久久精品亚洲 | 久久国产精品色av免费看 | 欧美成人一区二区 | 免费av试看 | 奇人奇案qvod | 天天色婷婷 | 丁香婷婷综合激情五月色 | 亚洲国产午夜视频 | wwwwwww黄 | 色偷偷97| 欧美日韩网站 | 免费av的网站 | 国产精品女同一区二区三区久久夜 | 久久999久久 | 国产麻豆成人传媒免费观看 | 精品一区二区三区久久久 | 国产亚洲高清视频 | 国产一二区视频 | 国内视频在线观看 | 青青河边草免费直播 | 免费在线观看视频a | 欧美精品久久人人躁人人爽 | 久久精品99久久久久久 | 蜜臀av夜夜澡人人爽人人 | 色5月婷婷| 国产97视频在线 | 成人在线观看影院 | 国产最新视频在线观看 | 蜜臀久久99静品久久久久久 | 国产成人免费av电影 | 2021国产视频 | 中文av资源站| 激情黄色av | 欧美一级日韩免费不卡 | 亚洲精品18日本一区app | 国产黄在线 | 九九精品视频在线 | av黄免费看| av.com在线 | 欧美成人中文字幕 | 亚洲精品videossex少妇 | 丁香色天天| 精品999在线观看 | 亚洲成人家庭影院 | 狠狠色狠狠综合久久 | 久久国产亚洲视频 | 亚洲精品视频在 | 色综合久久88色综合天天 | 伊人网av| 日韩三级成人 | 日韩在线电影 | 一区二区精品视频 | 夜夜夜夜操 | 久久综合精品国产一区二区三区 | 日韩中文字幕一区 | 色婷婷免费视频 | 日本中文一区二区 | 蜜臀av性久久久久av蜜臀三区 | 久久视频精品在线观看 | 中文字幕在线播放日韩 | 久青草视频在线观看 | 高清av在线| 久久综合九色综合97婷婷女人 | 丁香婷婷综合五月 | 涩涩色亚洲一区 | 99热最新地址 | 中文字幕免费观看视频 | 国产国产人免费人成免费视频 | 九热在线| 91一区啪爱嗯打偷拍欧美 | 欧美日韩中文在线视频 | 日韩免费在线观看视频 | 99欧美视频 | 三级大片网站 | 最近乱久中文字幕 | 伊人成人激情 | 天天射射天天 | 在线视频麻豆 | 欧美日韩在线免费观看视频 | 人人干人人艹 | 国产精品成人一区二区三区吃奶 | 成人超碰97 | 91看片淫黄大片在线播放 | 国产美女精品视频 | 激情网站 | 激情校园亚洲 | 天天综合天天做天天综合 | 国产成人99av超碰超爽 | 91精品网站| 999视频精品 | 看片黄网站 | 国产一区二区三区高清播放 | 99c视频在线 | 国产精品视频免费观看 | 国产成人三级在线 | 99免费视频 | 久久综合狠狠综合久久狠狠色综合 | 在线观看视频97 | 久久这里精品视频 | 久久午夜精品视频 | 亚洲狠狠婷婷 | 久久久久激情视频 | 久久精品二区 | 国产男女爽爽爽免费视频 | 欧美久久99 | 国产69精品久久99的直播节目 | 日韩午夜av电影 | 99精品国产一区二区三区不卡 | 亚洲欧洲av | 日韩欧美一区二区在线观看 | 91福利专区| 91精品国产一区二区在线观看 | 国产精品99久久久久的智能播放 | 欧美另类性 | 久久毛片视频 | av超碰免费在线 | 亚洲精品乱码久久久久久按摩 | 狠狠狠干 | 久久久久久久久久福利 | 亚洲91精品 | 97香蕉久久超级碰碰高清版 | 日韩免费观看视频 | 免费h漫在线观看 | 国产高清无av久久 | 国产精品美女久久久久久久久久久 | 日本公妇色中文字幕 | 青春草视频在线播放 | 成人免费观看完整版电影 | 久久av不卡| 在线91视频 | 蜜臀av夜夜澡人人爽人人 | 国产a视频免费观看 | 国产一二区在线观看 | 麻豆传媒视频在线播放 | 国产精品一区二区三区四区在线观看 | 天天操狠狠操 | 国产精品国产亚洲精品看不卡 | 在线观看av小说 | 91网站观看 | 精品国产乱码久久久久久1区二区 | 日韩精品aaa | 国产精品久久久久久久久久免费 | 日日噜噜噜噜夜夜爽亚洲精品 | 午夜骚影 | 成人cosplay福利网站 | 国模视频一区二区 | 午夜婷婷网 | 国产一区二区三区视频在线 | 成人a视频 | 精品国产自在精品国产精野外直播 | 伊人久久av | www亚洲国产 | 99re视频在线观看 | 五月天色婷婷丁香 | 国产精品 亚洲精品 | 色香网| 在线观看av大片 | 麻豆国产精品一区二区三区 | av专区在线 | 日韩色综合网 | 美州a亚洲一视本频v色道 | 精品在线一区二区三区 | 国产91粉嫩白浆在线观看 | 六月丁香社区 | 少妇搡bbbb搡bbb搡忠贞 | 91精品在线播放 | 久久er99热精品一区二区三区 | 亚洲在线视频网站 | 99精品国产高清在线观看 | 伊香蕉大综综综合久久啪 | 日本爱爱免费视频 | 久久精品国产一区 | 在线探花 | 国产精品成人免费 | 国产久草在线 | 成人h动漫在线看 | 国产精品成人免费精品自在线观看 | 在线观看视频在线 | 久久91久久久久麻豆精品 | 婷婷激情5月天 | 免费不卡中文字幕视频 | 国产小视频国产精品 | 久久人人爽人人爽 | 黄色毛片在线观看 | 久久夜色精品国产欧美一区麻豆 | 欧美日视频 | 乱男乱女www7788 | 久久久久久高清 | 黄色大片入口 | 黄色三级免费网址 | 青青草国产免费 | 中文字幕精品www乱入免费视频 | 久久久久欠精品国产毛片国产毛生 | 午夜精品久久久 | 五月综合色婷婷 | 色综合五月天 | 色人久久| 欧美性做爰猛烈叫床潮 | 可以免费看av | www日日夜夜 | 黄a网站 | 久久网址 | 日日爱网站 | 国精产品999国精产品岳 | 精品国产精品一区二区夜夜嗨 | 四虎影视8848aamm| 在线观看电影av | 美女网站视频一区 | 福利一区二区 | 中文网丁香综合网 | 国产精品99久久久久久久久久久久 | 狠狠撸电影 | 日本黄网站| 美女网站在线免费观看 | 国产午夜小视频 | 日韩h在线观看 | 黄色网址中文字幕 | 欧美天堂久久 | 精品国产乱码久久久久久浪潮 | 久久午夜鲁丝片 | 欧美精品久久久久a | 97超碰人人模人人人爽人人爱 | 九九热视频在线免费观看 | 808电影| 国产人成免费视频 | 日韩av伦理片 | 天天综合网天天综合色 | 色综合五月 | 欧美一级特黄aaaaaa大片在线观看 | 蜜臀av夜夜澡人人爽人人桃色 | 国产成人精品一区二区三区 | 国产一级免费播放 | 成人精品国产 | 日本不卡一区二区三区在线观看 | 日韩系列在线 | av一级片在线观看 | 97av视频在线观看 | 国产最新视频在线观看 | 久久视频在线观看免费 | 久久精品香蕉 | 黄色aa久久 | 亚在线播放中文视频 | 日韩精品视 | 日韩欧美99| 久久毛片网 | 亚洲欧洲成人 | 天天摸夜夜操 | 日韩网站一区二区 | 在线观看视频国产一区 | 久久国内视频 | 亚洲欧美视频一区二区三区 | 国产精品成人a免费观看 | 黄色免费视频在线观看 | 91视频大全| 国产精品夜夜夜一区二区三区尤 | 久久免费国产视频 | 99国产在线 | 久久精品99北条麻妃 | 99精品欧美一区二区蜜桃免费 | 久久精品综合一区 | 成人黄色大片在线观看 | 一区二区不卡视频在线观看 | 精品久久久免费 | 奇米影视8888在线观看大全免费 | 激情久久五月 | 91视频免费视频 | 一级精品视频在线观看宜春院 | 在线一区观看 | 久草综合在线观看 | 久久久久国产一区二区三区 | 国产91精品看黄网站在线观看动漫 | 精品国产_亚洲人成在线 | 99精品久久久久久久久久综合 | 欧美aⅴ在线观看 | 亚洲午夜精品久久久久久久久 | 亚洲国产成人av网 | 在线观看视频黄 | 久久涩涩网站 | 色中色亚洲 | 亚洲国产中文在线观看 | 日女人电影 | 久久国产精品久久久 | 中文字幕精品久久 | 色激情五月 | 91九色视频观看 | 亚洲电影网站 | 国产精品久久久久久爽爽爽 |