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

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

?? buildnfa.cpp

?? 一個大學時候做的編譯原理的實驗.實驗內容是正則表達式到NFA到DFA到最小化DFA最終生成詞法分析代碼的整個過程的演示.那時由于時間關系,詞法分析代碼自動生成部分還沒完成.
?? CPP
?? 第 1 頁 / 共 2 頁
字號:
#include "Globals.h"
//#include "MainFrm.h"
//#include "AutoMakeView1.h"

int R=20;//節點半徑
int d=4*R;
list<int>::iterator CurrentIter=NULL;//當前演示指針

int xadd=80;//用于演示中x坐標的一次增減大小量
int yadd=50;//用于演示中y坐標的一次增減大小量
int startx=50,starty=300;//用于演示的結點的默認的坐標

//以下是NFA的數據結構
CString rExp;//正則表達式
LETTER_LIST letterlist;
NFA objNFA;
NODE_LIST* NFA_List=NULL;
int StateSum;//狀態總數

///////////////////////////////////
CNODE_LIST cnodelist;
/////////////////////////////

//視圖顯示
list<int> operations;
list<State> drawstates;
list<ARC> arcs;
CPoint* StatesPoints;

/*以下是正則表達式到NFA的幾個函數*/
void Translate(CString& r);//轉換正則表達式
void GetLetters(CString& r);//獲取字母表
void RToNFA(CString& r,NFA_LIST& NFAlist,CNODE_LIST &cnodelist,STATE_STACK &statestack);//正則表達式到NFA
void TranslateNFA(NFA_LIST& NFAlist);//改變NFA的存儲結構
void GetStatesPos(CPoint& pt);//獲取節點坐標

void ClearNFA()//清空數據結構里保存的東西
{
	//////////////////
	cnodelist.clear();
	/////////////////////
	letterlist.clear();
	if(NFA_List!=NULL)
	{
        delete []NFA_List;
		NFA_List=NULL;
	}
	operations.clear();
	drawstates.clear();
	arcs.clear();
	if(StatesPoints!=NULL)
	{
		delete []StatesPoints;
		StatesPoints=NULL;
	}
}

bool BuildNFA(CString& r)//創建NFA
{
	if(r.IsEmpty())
	{
		AfxMessageBox("請選擇一個正則表達式進行操作!\n(雙擊列表中的一項)");
		return false;
	}
	CPoint pt(50,300);
	NFA_LIST NFAlist;
	//////////////////
	STATE_STACK statestack;
	//////////////////////
	Translate(r);
	GetLetters(r);
	RToNFA(r,NFAlist,cnodelist,statestack);
	TranslateNFA(NFAlist);
	GetStatesPos(pt);
	NFAlist.clear();
	return true;
}

/*正則表達式到NFA的幾個函數的實現*/

void Translate(CString& r)//轉換正則表達式,主要把連接符號以'&'標識出來
{
	list<char> chList;
	int i=0;
	r+='\0';
	int n=r.GetLength();
	///////////////////
	int num=0;//用于計算y的初始坐標是多少
	////////////////////////
    while(i<n-1)//以鏈表把轉換后的正則表達式保存起來
	{
		chList.push_back(r[i]);
//		if(r[i]>='a'&&r[i]<='z'||r[i]>='A'&&r[i]<='Z'||r[i]==')'||r[i]=='*')
		if(r[i]!='('&&r[i]!='|')
			//滿足此條件的字母后面加'&'
		{
//			if(r[i+1]>='a'&&r[i+1]<='z'||r[i+1]>='A'&&r[i+1]<='Z'||r[i+1]=='(')
			if(r[i+1]!=')'&&r[i+1]!='*'&&r[i+1]!='|'&&r[i+1]!='\0')
				chList.push_back('&');
		}
		/////////////////////
		if(r[i]=='|')
		{
			num++;
		}
		////////////////

		i++;
	}
	r.Empty();
	list<char>::iterator iter;
	for(iter=chList.begin();iter!=chList.end();iter++)
	{
		r+=*iter;
	}
	////////////////////
	if(num>5)
	{
		starty=num*60;
	}
	////////////////////
	
	chList.clear();//清空鏈表,釋放內存空間
}

void GetLetters(CString& r)
{
	int i=0;
	char letter[128];
	memset(letter,0,128);
	int n=r.GetLength();
	while(i<n)
	{
		if(r[i]!='&'&&r[i]!='|'&&r[i]!='*'&&r[i]!='('&&r[i]!=')')
		{
			//letterlist.push_back(r[i]);
			letter[r[i]]=r[i];
		}
		i++;
	}
	for(i=0;i<128;i++)
	{
		if(letter[i]!=0)
		{
			letterlist.push_back((char)letter[i]);
		}
	}
}

///////////////////////////////////////////////////////////////////
int max_(int a,int b)//返回兩者中的最大值
{
	if(a>b)
		return a;
	else
		return b;
}
int count(STATE_CHAIN &statechain)//用來計算狀態鏈表的狀態數
{
	int num=0;
	STATE_CHAIN::iterator iter;
	for(iter=statechain.begin();iter!=statechain.end();iter++)
	{
		num++;
	}
	return num;
}

void X_ADD(CNODE_LIST &cnodelist,STATE_LIST &statelist,int n)//x方向上的增加量,用于畫圖的方法
{
	int i;
	CNODE_LIST::iterator iter;
	STATE_LIST::iterator iter1;
	NODE_LIST::iterator iter2;
	for(iter1=statelist.begin();iter1!=statelist.end();iter1++)//對每一個結點的x值都增加值n
	{
		i=0;
		iter=cnodelist.begin();
		while(i!=*iter1)
		{
			iter++;
			i++;
		}
		iter->x+=n;		
	}
}

void Y_ADD(CNODE_LIST &cnodelist,STATE_LIST &statelist,int n)//x方向上的增加量,用于畫圖的方法
{
	int i;
	CNODE_LIST::iterator iter;
	STATE_LIST::iterator iter1;
	NODE_LIST::iterator iter2;
	for(iter1=statelist.begin();iter1!=statelist.end();iter1++)//對每一個結點的y值都增加值n
	{
		i=0;
		iter=cnodelist.begin();
		while(i!=*iter1)
		{
			iter++;
			i++;
		}
		iter->y+=n;		
	}
}

CNode FIND(CNODE_LIST cnodelist,State n)//找某一狀態的坐標結點
{
	int i=0;
	CNODE_LIST::iterator iter;
	iter=cnodelist.begin();
	while(i!=n)
	{
		iter++;
		i++;
	}
	return *iter;
}
///////////////////////////////////////////////////////////////////

NFA AddAnd(CNODE_LIST &cnodelist,STATE_STACK &statestack,NFA_LIST& NFAlist,NFA& val1,NFA& val2)//連接操作,返回新狀態的NFA
{
	ARC tem;
	NFA val;
	int i;
	NFA_LIST::iterator iter;

	//////////////////////////////////
	STATE_CHAIN::iterator iter1;
	STATE_CHAIN statechain,statechain1,statechain2;
	State state1,state2;
	//////////////////////////////////

	for(i=0,iter=NFAlist.begin();iter!=NFAlist.end();iter++,i++)//尋找第val1.end個節點
	{
		if(i==val1.end)//向此節點的相鄰節點鏈表加入一個節點
		{
			Node node;
			node.state=val2.start;
			node.symbol='\0';
			iter->push_back(node);
			
            operations.push_back(2);
			tem.symbol='\0';
			tem.start=val1.end;
			tem.end=val2.start;
			arcs.push_back(tem);
			
			break;
		}
	}
	
	val.start=val1.start;//以左操作數的開始狀態為初始狀態為新NFA的開始狀態
	val.end=val2.end;//以右操作數的開始狀態為接受狀態為新NFA的接受狀態

	///////////////////////////////////////
	statechain1=statestack.back();
	statestack.pop_back();//取狀態鏈表棧中的最頂不的鏈表
	statechain2=statestack.back();
	statestack.pop_back();
	state1=statechain2.front();
	state2=statechain2.back();
	i=FIND(cnodelist,state2).x-FIND(cnodelist,state1).x+xadd;
	X_ADD(cnodelist,statechain1,i);


//	statechain.push_back(val.start);//合并經過運算的狀態鏈表
	for(iter1=statechain2.begin();iter1!=statechain2.end();iter1++)
	{
		statechain.push_back(*iter1);
	}
	for(iter1=statechain1.begin();iter1!=statechain1.end();iter1++)
	{
		statechain.push_back(*iter1);
	}
	
//	statechain.push_back(val.end);
	statestack.push_back(statechain);
	statechain.clear();
	statechain1.clear();
	statechain2.clear();
	///////////////////////////////////////
	
	return val;
}

NFA AddOr(CNODE_LIST &cnodelist,STATE_STACK &statestack,NFA_LIST& NFAlist,NFA& val1,NFA& val2,State& StateNum)//選擇操作,返回新狀態的NFA
{
	ARC tem;
	NFA val;
	int i;
	NODE_LIST nodelist1,nodelist2;
	Node node;
	NFA_LIST::iterator iter;

	//////////////////////////////////
	STATE_CHAIN::iterator iter1,iter2;
	STATE_CHAIN statechain,statechain1,statechain2;
	State state1,state2;
	CNode cnode;
	//////////////////////////////////
	
	node.state=val1.start;
	node.symbol='\0';//添加一條空字符的轉換邊
	nodelist1.push_back(node);
	
	node.state=val2.start;
	node.symbol='\0';//添加一條空字符的轉換邊
	nodelist1.push_back(node);
	NFAlist.push_back(nodelist1);//向鄰接表加入兩個新的鏈表
	NFAlist.push_back(nodelist2);
	
	operations.push_back(1);
	drawstates.push_back(StateNum);
    val.start=StateNum++;//新建兩個新的狀態
	operations.push_back(1);
	drawstates.push_back(StateNum);
	val.end=StateNum++;


	///////////////////////////////////////
	statechain1=statestack.back();
	statestack.pop_back();//取狀態鏈表棧中的最頂不的鏈表
	statechain2=statestack.back();
	statestack.pop_back();
	X_ADD(cnodelist,statechain1,xadd);
	X_ADD(cnodelist,statechain2,xadd);
	Y_ADD(cnodelist,statechain1,yadd);
	Y_ADD(cnodelist,statechain2,-yadd);


	statechain.push_back(val.start);//合并經過運算的狀態鏈表
	for(iter1=statechain1.begin();iter1!=statechain1.end();iter1++)
	{
		statechain.push_back(*iter1);
	}
	for(iter1=statechain2.begin();iter1!=statechain2.end();iter1++)
	{
		statechain.push_back(*iter1);
	}
	statechain.push_back(val.end);
	statestack.push_back(statechain);
	state1=statechain1.back();
	state2=statechain2.back();

	cnode.x=startx;
	cnode.y=starty;
	cnodelist.push_back(cnode);//添加一個該狀態的結點,定義在這個鏈表的開頭
	cnode.x=max_(FIND(cnodelist,state1).x,FIND(cnodelist,state2).x)+xadd;
	cnode.y=(FIND(cnodelist,state1).y+FIND(cnodelist,state2).y)/2;
	cnodelist.push_back(cnode);
	statechain.clear();
	statechain1.clear();
	statechain2.clear();
	///////////////////////////////////////////////////////////

	
	operations.push_back(2);
	tem.symbol='\0';
	tem.start=val.start;
	tem.end=val1.start;
	arcs.push_back(tem);
	
	operations.push_back(2);
	tem.symbol='\0';
	tem.start=val.start;
	tem.end=val2.start;
	arcs.push_back(tem);
	
	
	for(i=0,iter=NFAlist.begin();iter!=NFAlist.end();iter++,i++)
	{
		if(i==val1.end)//向此節點的相鄰節點鏈表加入一個節點
		{
			Node node;
			node.state=val.end;
			node.symbol='\0';//添加一條空字符的轉換邊
			iter->push_back(node);
			
			operations.push_back(2);
			tem.symbol='\0';
			tem.start=val1.end;
			tem.end=val.end;
			arcs.push_back(tem);
			
			break;
		}
	}
	
	for(i=0,iter=NFAlist.begin();iter!=NFAlist.end();iter++,i++)
	{
		if(i==val2.end)//向此節點的相鄰節點鏈表加入一個節點
		{
			Node node;
			node.state=val.end;
			node.symbol='\0';//添加一條空字符的轉換邊
			iter->push_back(node);
			
            operations.push_back(2);
			tem.symbol='\0';
			tem.start=val2.end;
			tem.end=val.end;
			arcs.push_back(tem);
			
			break;
		}
	}
	nodelist1.clear();//清空鏈表,釋放內存空間
	return val;
}

NFA AddRepeat(CNODE_LIST &cnodelist,STATE_STACK &statestack,NFA_LIST& NFAlist,NFA& val1,State& StateNum)//閉包操作,返回新狀態的NFA
{
    NFA val;
	int i;
	Node node;
	NODE_LIST nodelist1,nodelist2;
	NFA_LIST::iterator iter;
	ARC tem;

	////////////////////////////////////////////////////////
	CNode cnode;
	STATE_CHAIN::iterator iter1;
	STATE_CHAIN statechain,statechain1;
	State state;
	/////////////////////////////////////////////////////////
	
	operations.push_back(1);
	drawstates.push_back(StateNum);
    val.start=StateNum++;//新建兩個新的狀態
	operations.push_back(1);
	drawstates.push_back(StateNum);
	val.end=StateNum++;

	/////////////////////////////////////////////////
	statechain1=statestack.back();
	statestack.pop_back();//取狀態鏈表棧中的最頂不的鏈表

	X_ADD(cnodelist,statechain1,xadd);
	statechain.push_back(val.start);//合并經過運算的狀態鏈表
	for(iter1=statechain1.begin();iter1!=statechain1.end();iter1++)
	{
		statechain.push_back(*iter1);
	}
	statechain.push_back(val.end);
	statestack.push_back(statechain);
	state=statechain1.back();


	cnode.x=startx;
	cnode.y=starty;
	cnodelist.push_back(cnode);//添加一個該狀態的結點,定義在這個鏈表的開頭
    cnode.x=FIND(cnodelist,state).x+xadd;
	cnode.y=FIND(cnodelist,state).y;
	cnodelist.push_back(cnode);

	statechain.clear();
	statechain1.clear();
	///////////////////////////////////////////////////////////
	
	node.state=val1.start;
	node.symbol='\0';//添加一條空字符的轉換邊
	nodelist1.push_back(node);
	operations.push_back(2);
	tem.symbol='\0';
	tem.start=val.start;
	tem.end=val1.start;
	arcs.push_back(tem);
	
	node.state=val.end;
	node.symbol='\0';//添加一條空字符的轉換邊
	nodelist1.push_back(node);
	operations.push_back(3);
	tem.symbol='\0';
	tem.start=val.start;
	tem.end=val.end;
	arcs.push_back(tem);
	
    NFAlist.push_back(nodelist1);//向鄰接表加入兩個新的鏈表
	NFAlist.push_back(nodelist2);
	
	for(i=0,iter=NFAlist.begin();iter!=NFAlist.end();iter++,i++)
	{
		if(i==val1.end)
		{
			Node node;
			node.state=val1.start;
			node.symbol='\0';//添加一條空字符的轉換邊
			iter->push_back(node);
            
			operations.push_back(3);//添加一個操作,1.為節點生成操作2.為直線邊3.為曲線邊
			tem.symbol='\0';
			tem.start=val1.end;
			tem.end=val1.start;
			arcs.push_back(tem);
			
			node.state=val.end;
			node.symbol='\0';//添加一條空字符的轉換邊
			iter->push_back(node);
			
			operations.push_back(2);//添加一個操作,1.為節點生成操作2.為直線邊3.為曲線邊
			tem.symbol='\0';
			tem.start=val1.end;
			tem.end=val.end;
			arcs.push_back(tem);
			break;
		}
	}
    nodelist1.clear();//清空鏈表,釋放內存空間
	return val;
}

void RToNFA(CString& r,NFA_LIST& NFAlist,CNODE_LIST &cnodelist,STATE_STACK &statestack)//正則表達式到NFA
{
    ///////////////////
	STATE_CHAIN statechain;
	///////////////////////


	list<NFA> l1;//NFA棧,NFA保存的是一個NFA的開始狀態和終止狀態
	list<Symbol> l2;//符號棧,用于保存正則表達式運算符
	int i=0;//標志當前字符在正則表達式字符串中的位置
	char ch;//暫存出棧字符
    NFA val1,val2,val;//保存NFA運算操作數和結果
	State StateNum=0;//當前狀態數
	ARC tem;
	int n=r.GetLength();
	
	while(i<n)//如果正則表達式還沒結束,do
	{
//		if(r[i]>='a'&&r[i]<='z'||r[i]>='A'&&r[i]<='Z')//遇到正則表達式
		if(r[i]!='('&&r[i]!=')'&&r[i]!='*'&&r[i]!='|'&&r[i]!='&')
		{
			NODE_LIST nodelist1;
			NODE_LIST nodelist2;

			////////////////////////////////
			CNode cnode;
			///////////////////////////////

		//	NFA nfa;
			Node node;
			operations.push_back(1);//添加一個操作,1.為節點生成操作2.為直線邊3.為曲線邊
			drawstates.push_back(StateNum);
			val.start=StateNum++;//新建兩個新的狀態
			operations.push_back(1);//添加一個操作,1.為節點生成操作2.為直線邊3.為曲線邊
			drawstates.push_back(StateNum);
			node.state=val.end=StateNum++;
			node.symbol=r[i];
            l1.push_back(val);//nfa進棧

			///////////////////////////////////
			cnode.x=startx;
			cnode.y=starty;
			cnodelist.push_back(cnode);
			cnode.x=startx+xadd;
			cnode.y=starty;
			cnodelist.push_back(cnode);
			statechain.push_back(val.start);//添加兩個狀態組成的鏈表
			statechain.push_back(val.end);
			statestack.push_back(statechain);
			statechain.clear();
			/////////////////////////////////////

			tem.symbol=r[i];
			tem.start=val.start;
			tem.end=val.end;

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
欧美日韩精品免费| 91精品国产91久久久久久一区二区| 日韩精品亚洲专区| 亚洲成人在线免费| 日本欧美在线看| 久久电影网电视剧免费观看| 老司机午夜精品| 激情六月婷婷综合| 国产成人精品免费网站| www.亚洲精品| 色94色欧美sute亚洲线路二 | 欧美精品一级二级三级| 欧美撒尿777hd撒尿| 91精品中文字幕一区二区三区| 日韩午夜激情免费电影| 久久久综合激的五月天| 成人免费在线播放视频| 亚洲午夜三级在线| 精品无人码麻豆乱码1区2区 | 91污片在线观看| 在线精品视频一区二区三四| 欧美日韩小视频| 精品福利一二区| 亚洲美女一区二区三区| 三级不卡在线观看| 国产丶欧美丶日本不卡视频| 91免费看`日韩一区二区| 在线电影一区二区三区| 国产欧美一区二区三区在线老狼| 亚洲制服丝袜av| 久久成人久久鬼色| 日本乱人伦aⅴ精品| 久久久精品国产99久久精品芒果| 亚洲综合视频在线观看| 激情图片小说一区| 欧美婷婷六月丁香综合色| 欧美精品一区二区在线观看| 亚洲与欧洲av电影| 国产aⅴ综合色| 制服.丝袜.亚洲.中文.综合| 中文字幕免费观看一区| 天堂蜜桃91精品| 91在线精品秘密一区二区| 日韩一区二区视频| 一区二区三区欧美日| 国产成人亚洲精品狼色在线 | 春色校园综合激情亚洲| 欧美一区午夜视频在线观看| 亚洲精品一二三| 国产91综合网| 精品美女一区二区| 日欧美一区二区| 欧美少妇一区二区| 亚洲精品乱码久久久久久黑人 | 欧美一区三区四区| 亚洲综合在线第一页| 99久久精品国产一区| 国产日韩欧美高清在线| 久久成人精品无人区| 日韩女优电影在线观看| 午夜欧美视频在线观看| 精品污污网站免费看| 亚洲一级电影视频| 欧美日韩国产一区二区三区地区| 亚洲免费观看高清| 91极品美女在线| 中文字幕亚洲欧美在线不卡| 丰满亚洲少妇av| 亚洲国产激情av| 风间由美一区二区三区在线观看 | 成人免费视频国产在线观看| 精品久久久久久久久久久久久久久| 亚洲国产成人tv| 欧美日韩一区二区三区在线 | 高清成人在线观看| 久久精品夜色噜噜亚洲aⅴ| 国产乱人伦偷精品视频不卡| 久久精品在线免费观看| 成人精品国产一区二区4080| 中国av一区二区三区| 粉嫩13p一区二区三区| 国产精品欧美久久久久一区二区| 成人免费视频视频| 亚洲精品午夜久久久| 在线观看三级视频欧美| 视频一区免费在线观看| xnxx国产精品| 97久久精品人人做人人爽| 一区二区三区欧美亚洲| 欧美一级理论片| 国产美女av一区二区三区| 中文欧美字幕免费| 欧美日韩在线播放三区| 久久精品国产秦先生| 国产精品免费丝袜| 欧美日韩一区二区三区高清 | 欧美精品自拍偷拍动漫精品| 青青草97国产精品免费观看无弹窗版| 日韩精品专区在线影院重磅| 成人精品小蝌蚪| 亚洲一区成人在线| 久久久av毛片精品| 欧洲精品视频在线观看| 国模一区二区三区白浆| 亚洲精品亚洲人成人网 | 色婷婷亚洲精品| 免费av网站大全久久| 日本一区二区三级电影在线观看| 欧美亚洲国产一区二区三区va| 久久99精品一区二区三区| 国产精品久久久久影院亚瑟 | 亚洲在线视频一区| 精品99久久久久久| 欧美日韩亚洲丝袜制服| 国产成人av电影免费在线观看| 亚洲一区视频在线观看视频| 久久欧美一区二区| 欧美乱妇15p| 99精品久久免费看蜜臀剧情介绍| 麻豆91精品91久久久的内涵| 一区二区在线观看视频在线观看| 久久夜色精品一区| 欧美精品在线一区二区| 日本高清不卡一区| 成人18视频在线播放| 美女精品一区二区| 亚欧色一区w666天堂| 亚洲精品菠萝久久久久久久| 中文字幕欧美激情| 久久久亚洲精品一区二区三区| 欧美一区二区在线免费播放| 色噜噜狠狠成人中文综合| 国产成人在线视频网址| 激情综合色综合久久| 日本三级亚洲精品| 婷婷六月综合网| 亚洲国产精品一区二区尤物区| 亚洲日本丝袜连裤袜办公室| 中文av一区二区| 国产精品三级av| 国产日韩精品一区二区三区| 亚洲精品一区二区三区99| 欧美大片日本大片免费观看| 4438成人网| 欧美一区二区三区四区久久| 91精品国产日韩91久久久久久| 欧美中文字幕一区二区三区亚洲| 在线免费亚洲电影| 欧美视频一区二| 在线不卡一区二区| 91精品一区二区三区在线观看| 91精品国产欧美一区二区18| 欧美一区二区三区视频免费播放 | 国产乱码一区二区三区| 国产一区欧美一区| 国产高清不卡二三区| 国产91丝袜在线播放| www.99精品| 欧美性猛片xxxx免费看久爱| 欧美日韩久久久| 日韩欧美国产麻豆| 久久久亚洲综合| 亚洲视频一区二区在线| 午夜久久久久久久久久一区二区| 日韩在线a电影| 国产资源精品在线观看| 国产成人超碰人人澡人人澡| 色综合久久久久综合| 欧美老女人在线| 久久色在线观看| 一区二区三区在线不卡| 首页亚洲欧美制服丝腿| 国产一区二区三区免费看 | 国产精品正在播放| k8久久久一区二区三区| 欧美日韩另类一区| www成人在线观看| 亚洲伦理在线免费看| 麻豆久久久久久久| 不卡一区二区三区四区| 欧美日韩成人综合天天影院| 久久久久免费观看| 亚洲综合色自拍一区| 国产真实乱子伦精品视频| 91片黄在线观看| 欧美mv和日韩mv的网站| 自拍视频在线观看一区二区| 日韩精品免费专区| 成人一区二区视频| 日韩视频在线观看一区二区| 国产精品传媒在线| 日韩国产精品久久久久久亚洲| 成人少妇影院yyyy| 日韩午夜精品视频| 亚洲一区二区三区四区中文字幕| 国产伦精一区二区三区| 欧美日韩国产一级| 亚洲色图19p| 国产精品一二三区在线| 欧美精品vⅰdeose4hd|