亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? formulatree.h

?? 一個基于H.wang的謂詞演算公式的機器證明的vc實現
?? H
字號:
void mystrcpy(char *s1,char *s2){
	int i;
	for(i=0;i<(int)strlen(s2);i++)
		s1[i]=s2[i];
	s1[i]='\0';
}
void mystrncpy(char *s1,char *s2,int n){
	for(int i=0;i<n;i++)
		s1[i]=s2[i];
}
template <class Type> class FormulaTree;	
template <class Type> class TreeNode{
	friend class FormulaTree<Type>;
public:
	TreeNode ( ):leftChild (NULL), rightChild (NULL) {}
    TreeNode ( Type item,int value,TreeNode<Type> *left = NULL, TreeNode<Type> *right = NULL ): data (item),flag(value), leftChild (left), rightChild(right) { }    
	Type GetData ( ) const { return data; } 
private:
    TreeNode<Type> *leftChild, *rightChild;      
    Type data;
	int flag;
};
template <class Type> class FormulaTree {	
public:
    FormulaTree ( ) : root (NULL) { }
	FormulaTree(Type *str);
	FormulaTree(const FormulaTree<Type> &s){ root= Copy(s.root);}
	FormulaTree ( Type value){RefValue =value;  root =NULL;}
    virtual ~FormulaTree ( ) { destroy ( root ); }
	virtual void Insert (Type *s );
	void Add(TreeNode <Type> *&current,Type *s);
	void preorder(TreeNode <Type> *current);
	void inorder(TreeNode <Type>* current);
	void postorder1(TreeNode<Type>* current);
	void postorder2(TreeNode<Type>* current);
	void postorder3(TreeNode<Type>* current);
	void postorder4(TreeNode<Type>* current);
    void postorder(TreeNode<Type>* current);
	void disp ();
	TreeNode<Type> *Copy(TreeNode <Type>* current);
	void ToCNF1(TreeNode <Type> *&current);
	void ToCNF2(TreeNode <Type> *&current);
	void ToCNF3(TreeNode <Type> *&current);
	void ToCNF4(TreeNode <Type> *&current);
	void ToDNF4(TreeNode <Type> *&current);
	char* ToCNF();
	char* ToDNF();
    const TreeNode <Type> *GetRoot ( ) const{ return root; } 
	bool Isalp(char s){ return ((s<='z'&&s>='a')||(s<='Z'&&s>='A'));}
	char *Change1(char *str);
	char *Change2(char *str);
	char * Toinfix1(char *str);
	char * Toinfix2(char *str);
	int number();
 private:
    TreeNode <Type> *root;
	int i;
	Type *Formu;
    Type RefValue; //標志結束符
    void destroy(TreeNode<Type> *current);
	int number(TreeNode <Type> *p);
};
template<class Type>
FormulaTree<Type>::FormulaTree(Type *str){
    RefValue='@'; 
	Type *s=Change2(Change1(str));
	 Insert(s);
}
template<class Type>
void FormulaTree <Type>::postorder1(TreeNode<Type>* current){
	if(current!=NULL){
		postorder1(current->leftChild);
	    postorder1(current->rightChild);
	    ToCNF1(current);
	    if(i!=1)i=0;
	}
}
template<class Type>
void FormulaTree <Type>:: postorder2(TreeNode<Type>* current){ 
	if(current!=NULL){
		postorder2(current->leftChild);
		postorder2(current->rightChild);
		ToCNF2(current);
		if(i!=1)i=0;
	}
}
template<class Type>
void FormulaTree <Type>:: postorder3(TreeNode<Type>* current){
	if(current!=NULL){
		postorder3(current->leftChild);
		postorder3(current->rightChild);
		ToCNF3(current);
		if(i!=1)i=0;
	}
}
template<class Type>
void FormulaTree <Type>:: postorder4(TreeNode<Type>* current){
	if(current!=NULL){
		postorder4(current->leftChild);
		postorder4(current->rightChild);
		ToCNF4(current);
		if(i!=1)i=0;
	}
}
template<class Type>
void FormulaTree <Type>:: postorder(TreeNode<Type>* current){
	 if(current!=NULL){
		 postorder(current->leftChild);
		postorder(current->rightChild);
		ToDNF4(current);
		 if(i!=1)i=0;
	 }
 }
template<class Type>
TreeNode<Type> * FormulaTree <Type>::Copy(TreeNode <Type>* current){
		if(current==NULL) return NULL;
		TreeNode<Type> *temp=new TreeNode<Type>;
		temp->data=current->data;
		temp->leftChild=Copy(current->leftChild);
		temp->rightChild=Copy(current->rightChild);
		return temp;
}

template <class Type> void FormulaTree <Type>:: destroy ( TreeNode<Type> *current ){
	if (current != NULL&&current->flag==0 ) 
	{  //current->flag++;
       destroy ( current->leftChild );
       destroy ( current->rightChild );
	   delete current;
    }
}
template <class Type> void FormulaTree <Type> ::Insert(Type *s){
	i=0;
	Add(root,s);
}
template <class Type> void FormulaTree<Type> ::Add(TreeNode <Type> *&current,Type* s ){
     Type item;item=s[i];i++;int value=0;
	 if( item != RefValue)
	 {current=new TreeNode <Type> (item,value);
	           if ( current == NULL ) exit (1); 
            Add ( current->leftChild,s);
			Add ( current->rightChild,s);
        }
        else current = NULL; 
}	
template <class Type> void FormulaTree<Type>::ToCNF1(TreeNode<Type> *&p){ 
	TreeNode<Type> *temp=new TreeNode<Type>;temp->flag=0;
	TreeNode<Type> *q=new TreeNode<Type>;q->flag=0;
	TreeNode<Type> *l=new TreeNode<Type>;l->flag=0;
	TreeNode<Type> *r=new TreeNode<Type>;r->flag=0;
	Type t=p->data;
	switch(t)
	{ 
	case '>':
		p->data='+';
		temp->data='!';temp->leftChild=NULL;
		temp->rightChild=p->leftChild;
		p->leftChild=temp;
		i=1;break;
	case '=':
		p->data='*';
		temp->data=q->data='+';
		l->data='!';l->leftChild=NULL;l->rightChild=p->leftChild;
		temp->leftChild=l;temp->rightChild=p->rightChild;
		r->data='!';r->leftChild=NULL;r->rightChild=p->rightChild;
		q->rightChild=r;q->leftChild=p->leftChild;
		p->leftChild=temp;p->rightChild=q;
		i=1;
		break;
	default: break;
	}
}
template <class Type> void FormulaTree<Type>::ToCNF2(TreeNode<Type> *&p){
	TreeNode<Type>*temp=p->rightChild;
	TreeNode<Type> *l=new TreeNode<Type>;l->flag=0;
	TreeNode<Type> *r=new TreeNode<Type>;r->flag=0;
	 if(p->data=='!'&&temp->data=='+')
	 {p->data='*';
	 l->data=r->data='!';
	 l->leftChild=r->leftChild=NULL;
	 l->rightChild=temp->leftChild;r->rightChild=temp->rightChild;
	 p->leftChild=l;p->rightChild=r;
	 i=1;
	 }
	 else if(p->data=='!'&&temp->data=='*')
	 {p->data='+';
	 l->data=r->data='!';
	 l->leftChild=r->leftChild=NULL;
	 l->rightChild=temp->leftChild;r->rightChild=temp->rightChild;
	 p->leftChild=l;p->rightChild=r;
	 i=1;
	 }
}

template <class Type> void FormulaTree<Type>::ToCNF3(TreeNode<Type> *&p){
	TreeNode<Type>*temp=p->rightChild; 
	if(p->data=='!'&&temp->data=='!')
	{TreeNode<Type>*q=temp->rightChild;p->data=q->data;
	p->leftChild=q->leftChild;
	p->rightChild=q->rightChild;
	i=1;
	}
}
template <class Type> void FormulaTree<Type>::ToCNF4(TreeNode<Type> *&p){
	TreeNode<Type>*temp1=p->rightChild;
	if(p->data=='+'&&temp1->data=='*'){ 
		TreeNode<Type>*q=new TreeNode<Type>;q->flag=0;
	    q->data='+';q->leftChild=p->leftChild;
	    q->rightChild=temp1->leftChild;
		TreeNode<Type>*ptr=new TreeNode<Type>;
		ptr->data='+';ptr->flag=0;
		ptr->leftChild=p->leftChild;ptr->rightChild=temp1->rightChild;
		p->data='*';p->leftChild=q;p->rightChild=ptr;
		i=1;
	  }
	TreeNode<Type> *temp2=p->leftChild;
	if(p->data=='+'&&temp2->data=='*'){
		TreeNode<Type>*q=new TreeNode<Type>;q->flag=0;
		q->data='+';q->rightChild=p->rightChild;
	    q->leftChild=temp2->rightChild;
		TreeNode<Type>*ptr=new TreeNode<Type>;
		ptr->data='+';ptr->flag=0;
		ptr->rightChild=p->rightChild;ptr->leftChild=temp2->leftChild;
		p->data='*';p->leftChild=ptr;p->rightChild=q;
		i=1;
	}
}
  
template <class Type>void FormulaTree<Type>::ToDNF4(TreeNode<Type> *&p){
	TreeNode<Type>*temp1=p->rightChild;
    if(p->data=='*'&&temp1->data=='+'){
		TreeNode<Type>*q=new TreeNode<Type>;
		q->data='*';q->flag=0;q->leftChild=p->leftChild;
	    q->rightChild=temp1->leftChild;
        TreeNode<Type>*ptr=new TreeNode<Type>;
		ptr->data='*';ptr->flag=0;
		ptr->leftChild=p->leftChild;ptr->rightChild=temp1->rightChild;
		p->data='+';p->leftChild=q;p->rightChild=ptr;
		i=1;
	} 
    TreeNode<Type> *temp2=p->leftChild;
    if(p->data=='*'&&temp2->data=='+'){
		TreeNode<Type>*q=new TreeNode<Type>;
		q->data='*';q->flag=0;q->rightChild=p->rightChild;
	    q->leftChild=temp2->rightChild;
		TreeNode<Type>*ptr=new TreeNode<Type>;
		ptr->data='*';ptr->flag=0;ptr->rightChild=p->rightChild;ptr->leftChild=temp2->leftChild;
		p->data='+';p->leftChild=ptr;p->rightChild=q;
		i=1;
  }
}
 template <class Type>void FormulaTree<Type> ::preorder (TreeNode <Type>* p){
	 if(p!=NULL){
		 Formu[i]=p->data;
		 i++;
		 preorder(p->leftChild);
		 preorder(p->rightChild);
	 }
 }
 template <class Type>void FormulaTree<Type> ::inorder(TreeNode <Type>* current){
      mystack < TreeNode <Type>* >mystack;
      TreeNode <Type>*p = current;
	  while (p!= NULL || !mystack.IsEmpty ()){
		 while (p != NULL){
			 mystack.push(p);
             p = p->leftChild;
		 }
		 if (!mystack.IsEmpty ()){
			 p = mystack.top ();
             mystack.pop ();
             p= p->rightChild;        
		 }
	  }
 }
 template <class Type> char* FormulaTree<Type> ::ToCNF(){ 
	 i=2;while(i!=0){ i=2;postorder1(root);}
     i=2;while(i!=0){ i=2;postorder2(root);}
	 i=2;while(i!=0){ i=2;postorder3(root);}
	 i=2;while(i!=0){ i=2;postorder4(root);}
	 int num=number();
	  Formu=new Type[num*2];
	  preorder (root);
	  Formu[i]='\0';
	  char *s;s=new char[strlen(Formu)];
	  s=Toinfix1(Formu);
	  delete []Formu;
	  return s;
 }
 template <class Type> char* FormulaTree<Type>::ToDNF(){
	 i=2;while(i!=0){ i=2;postorder1(root);}
     i=2;while(i!=0){ i=2;postorder2(root);}
	 i=2;while(i!=0){ i=2;postorder3(root);}
	 i=2;while(i!=0){ i=2;postorder(root);}
	  int num=number();
	  Formu=new Type[num*2];
      preorder (root);
	  Formu[i]='\0';
	  char *s;s=new char[strlen(Formu)];
	  s=Toinfix2(Formu);
	  delete []Formu;
	  return s;
 }
 template <class Type> void FormulaTree<Type> ::disp(){
      inorder(root);
 }
template <class Type> 
char *FormulaTree<Type> ::Change1(char *str){//將公式轉為前綴
	mystack<char> temp,operat;
	for(int i=strlen(str)-1;i>=0;i--){
		if( ('a'<=str[i]&&str[i]<='z')||('A'<=str[i]&&str[i]<='Z') )
			temp.push(str[i]);
		else{
			if(str[i]=='('){
				char c;
				while( ( c=operat.top() )!=')' ){ temp.push(c); operat.pop(); }
				operat.pop(); 
			}
			else if(str[i]=='!')
				temp.push(str[i]);
			else
				operat.push(str[i]);
		}
	}
	while(operat.IsEmpty()==false){
		temp.push(operat.top());
		operat.pop();
	}
	char *s;
	s=new char[strlen(str)+1];
	int j=0;
	while(temp.IsEmpty()==false){
		s[j++]=temp.top();
		temp.pop();
	}
	s[j]='\0';
	return s;
}
template <class Type> 
char *FormulaTree<Type> ::Change2(char *s){  
	int i=0,j=0;
	char *str;str=new char[5*strlen(s)];
		for(i=0;i<(int)strlen(s);i++)
		{
			if(s[i]=='!')
		    {str[j]=s[i];
			str[++j]='@';
			j++;}
			else if(Isalp(s[i]))
			{str[j]=s[i];
			 str[++j]='@';
			 str[++j]='@';
			 j++;
			}
			else
			{	str[j]=s[i]; j++;
			}
		}
		str[j]='\0';
	return str;
}
template <class Type> 
char *FormulaTree<Type> ::Toinfix1(char *str){
	mystack<char *> st;
	for(int i=strlen(str)-1;i>=0;i--){
		if( ('a'<=str[i]&&str[i]<='z')||('A'<=str[i]&&str[i]<='Z') ){
			char *temp=new char[2];
			temp[0]=str[i];
			temp[1]='\0';
			st.push(temp);
		}
		else if(str[i]=='!'){
			char *op=st.top(),*temp;
			st.pop();
			temp=new char[strlen(op)+4];
			temp[0]='!';
			mystrcpy(temp+1,op);
			temp[strlen(op)+1]='\0';
			st.push(temp);
			delete []op;
		}
else if(str[i]=='+')
{			char *op1,*op2;
			op1=st.top(); st.pop();
			op2=st.top(); st.pop();
			char *temp=new char[strlen(op1)+strlen(op2)+6];
			mystrcpy(temp,op1);
			temp[strlen(op1)]=str[i];
			mystrcpy(temp+strlen(op1)+1,op2);
			temp[strlen(op1)+strlen(op2)+1]='\0';
			st.push(temp);
			delete []op1;delete []op2;
		}
		else if(str[i]=='*'){
			int k1=0,k2=0;
			char *op1,*op2;
			op1=st.top(); st.pop();
			op2=st.top(); st.pop();
			char *temp=new char[strlen(op1)+strlen(op2)+6];
			if(strlen(op1)>2&&op1[0]!='(')temp[k1++]='(';
			mystrcpy(temp+k1,op1);
			if(strlen(op1)>2&&op1[0]!='(')temp[strlen(op1)+k1]=')';
			temp[strlen(op1)+k1*2]=str[i];
			if(strlen(op2)>2&&op2[0]!='('){temp[strlen(op1)+2*k1+1]='(';k2++;}
			mystrcpy(temp+strlen(op1)+2*k1+k2+1,op2);
			if(strlen(op2)>2&&op2[0]!='(')temp[strlen(op1)+strlen(op2)+2*k1+k2+1]=')';
			temp[strlen(op1)+strlen(op2)+2*k1+2*k2+1]='\0';
			st.push(temp);
			delete []op1;delete []op2;
		}
	}
	char *temp=st.top();
	return temp;
}
template <class Type>
char *FormulaTree<Type> ::Toinfix2(char *str){
	mystack<char *> st;
	for(int i=strlen(str)-1;i>=0;i--){
		if( ('a'<=str[i]&&str[i]<='z')||('A'<=str[i]&&str[i]<='Z') ){
			char *temp=new char[2];
			temp[0]=str[i];
			temp[1]='\0';
			st.push(temp);
		}
		else if(str[i]=='!'){
			char *op=st.top(),*temp;
			st.pop();
			temp=new char[strlen(op)+4];
			temp[0]='!';
			mystrcpy(temp+1,op);
			temp[strlen(op)+1]='\0';
			st.push(temp);
			delete []op;
		}
else if(str[i]=='*')
{			char *op1,*op2;
			op1=st.top(); st.pop();
			op2=st.top(); st.pop();
			char *temp=new char[strlen(op1)+strlen(op2)+6];
			mystrcpy(temp,op1);
			temp[strlen(op1)]=str[i];
			mystrcpy(temp+strlen(op1)+1,op2);
			temp[strlen(op1)+strlen(op2)+1]='\0';
			st.push(temp);
			delete []op1;delete []op2;
		}
		else if(str[i]=='+'){
			int k1=0,k2=0;
			char *op1,*op2;
			op1=st.top(); st.pop();
			op2=st.top(); st.pop();
			char *temp=new char[strlen(op1)+strlen(op2)+6];
			if(strlen(op1)>2&&op1[0]!='(')temp[k1++]='(';
			mystrcpy(temp+k1,op1);
			if(strlen(op1)>2&&op1[0]!='(')temp[strlen(op1)+k1]=')';
			temp[strlen(op1)+k1*2]=str[i];
			if(strlen(op2)>2&&op2[0]!='('&&op2[1]!='+'&&op2[2]!='+'){temp[strlen(op1)+2*k1+1]='(';k2++;}
			mystrcpy(temp+strlen(op1)+2*k1+k2+1,op2);
			if(strlen(op2)>2&&op2[0]!='('&&op2[1]!='+'&&op2[2]!='+')temp[strlen(op1)+strlen(op2)+2*k1+k2+1]=')';
			temp[strlen(op1)+strlen(op2)+2*k1+2*k2+1]='\0';
			st.push(temp);
			delete []op1;delete []op2;
		}
	}
	char *temp=st.top();
	return temp;
}
template <class Type> 
int FormulaTree<Type> ::number(){
	return number(root);
}
template <class Type> 
int FormulaTree<Type> ::number(TreeNode<Type> *p){
	if(p==NULL)
		return 0;
	else
		return 1+number(p->leftChild)+number(p->rightChild);
}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
91无套直看片红桃| 欧美www视频| 激情图片小说一区| 一区二区三区在线免费| 国产视频不卡一区| 欧美v亚洲v综合ⅴ国产v| 日本电影亚洲天堂一区| 国产一区二区三区精品欧美日韩一区二区三区 | 久久69国产一区二区蜜臀| 最新日韩av在线| 久久久久国产免费免费| 91在线免费视频观看| 激情综合五月天| 蜜桃精品在线观看| 亚洲成人一区在线| 亚洲在线视频网站| 樱花草国产18久久久久| 欧美激情一区二区在线| 777亚洲妇女| 欧美精品v国产精品v日韩精品| 色综合网站在线| www.亚洲国产| av亚洲精华国产精华精| 美女一区二区久久| 精品一区二区影视| 亚洲bdsm女犯bdsm网站| 一区二区在线看| 亚洲精品videosex极品| 亚洲精选视频在线| 亚洲成人在线观看视频| 亚洲va韩国va欧美va| 偷拍与自拍一区| 午夜免费久久看| 三级在线观看一区二区| 天天操天天色综合| 亚洲人成伊人成综合网小说| 亚洲日本欧美天堂| 中文字幕一区二区三| www国产精品av| 日本一区二区三区高清不卡| 欧美国产日韩a欧美在线观看| 久久九九影视网| www成人在线观看| 国产精品毛片高清在线完整版| 国产精品激情偷乱一区二区∴| 亚洲免费观看高清| 午夜免费久久看| 亚洲成a人v欧美综合天堂| 天天操天天色综合| 久久99这里只有精品| 国产激情视频一区二区在线观看| 国产精品99久久久久久久vr| 国产自产高清不卡| 成人午夜激情在线| 色综合久久综合| 欧洲精品在线观看| 91精品一区二区三区在线观看| 日韩欧美一级在线播放| 久久婷婷色综合| 久久先锋资源网| 亚洲色大成网站www久久九九| 依依成人综合视频| 天堂蜜桃一区二区三区| 加勒比av一区二区| 国产麻豆9l精品三级站| 国产成人啪午夜精品网站男同| 成人av动漫在线| 欧美精品丝袜久久久中文字幕| 日韩视频中午一区| 制服丝袜在线91| 久久久久综合网| 亚洲免费观看在线视频| 欧美a级理论片| 成人国产在线观看| 欧美精品一二三| 中文一区二区完整视频在线观看 | 韩国毛片一区二区三区| 成人免费看的视频| 欧美日韩www| 欧美国产禁国产网站cc| 免费的成人av| 成人h动漫精品一区二区| 欧美一区二区三区小说| 国产日产欧美一区二区三区| 午夜影院久久久| 99精品视频中文字幕| 欧美成人性福生活免费看| 一区二区在线观看视频在线观看| 午夜电影网亚洲视频| 成人久久久精品乱码一区二区三区| 欧美日韩在线三级| 国产精品少妇自拍| 国产自产视频一区二区三区| 欧美区一区二区三区| 一区二区三区免费在线观看| 国产精品一区二区在线观看不卡 | 久久精品欧美日韩| 日本不卡一二三| 3d成人h动漫网站入口| 亚洲一线二线三线视频| 一本一道久久a久久精品| 亚洲国产成人一区二区三区| 国产精品影视天天线| 日韩免费高清av| 天堂成人免费av电影一区| 在线观看www91| 91麻豆精东视频| 亚洲精品视频自拍| 成人一区二区三区| 亚洲视频小说图片| 成人黄色a**站在线观看| 自拍偷拍亚洲综合| 99久久精品99国产精品| 亚洲欧美乱综合| 99精品久久久久久| 亚洲卡通动漫在线| 欧美唯美清纯偷拍| 亚洲欧美综合在线精品| 99久久精品国产毛片| 中文字幕亚洲一区二区av在线| 91麻豆swag| 一区二区三区四区视频精品免费 | 国产91富婆露脸刺激对白| 欧美精品一区二区不卡| 激情丁香综合五月| 久久久精品影视| 国产成人亚洲精品青草天美| 日韩视频一区二区三区| 丝瓜av网站精品一区二区| 911精品国产一区二区在线| 日日夜夜免费精品| 91精品国产乱码久久蜜臀| 日产精品久久久久久久性色| 欧美日韩大陆在线| 国产一区啦啦啦在线观看| 久久久99久久| 91传媒视频在线播放| 午夜精品久久久久| 精品国产伦一区二区三区观看方式| 国产一区欧美二区| 亚洲精品大片www| 欧美日韩卡一卡二| 国模一区二区三区白浆| 久久精品日韩一区二区三区| 在线视频国产一区| 视频一区二区国产| 国产日韩三级在线| 日本韩国欧美三级| 青青草成人在线观看| 欧美韩国日本不卡| 99re成人精品视频| 视频一区国产视频| 国产精品麻豆网站| 欧美日韩极品在线观看一区| 国产激情精品久久久第一区二区 | 精品视频在线免费看| 蜜臀国产一区二区三区在线播放| 欧美va亚洲va在线观看蝴蝶网| 99久久精品免费看国产免费软件| 性久久久久久久久久久久| 国产欧美日产一区| 欧美三级视频在线| 成人黄色片在线观看| 亚洲国产中文字幕在线视频综合 | 国产婷婷色一区二区三区在线| 在线亚洲+欧美+日本专区| 精品一区二区三区不卡| 亚洲综合丝袜美腿| 久久久久久久电影| 91精品国产欧美一区二区成人| 成人白浆超碰人人人人| 激情偷乱视频一区二区三区| 亚洲欧美日韩一区二区| 久久精品人人做人人爽97 | 亚洲精品一二三| 欧美精品一区二区三区久久久 | 国产成人福利片| 麻豆专区一区二区三区四区五区| 国产精品二三区| 久久久久久久久久久久久久久99| 91精彩视频在线观看| 成人精品视频网站| 老司机精品视频在线| 亚洲18色成人| 中文字幕在线不卡一区| 久久综合色鬼综合色| 欧美日韩在线观看一区二区| 91美女在线观看| 国产在线精品免费| 麻豆成人久久精品二区三区小说| 亚洲精品国久久99热| 国产精品高潮呻吟久久| 久久免费电影网| 精品久久久久久久久久久久久久久久久 | 一区二区三区影院| 国产精品免费看片| 欧美日韩成人在线一区| 国产v日产∨综合v精品视频| 琪琪久久久久日韩精品| 天天影视涩香欲综合网|