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

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

?? cchessmove.h

?? 中國象棋人機對弈
?? H
?? 第 1 頁 / 共 2 頁
字號:
// CChessMove.h


#include "CChessDef.h"



/////////////////// Data Define ////////////////////////////////////////////////

CCHESSMOVE MoveList[12][80] ;	// 存儲產生的著法隊列
int nMoveCount  ;				// 存儲當前搜索深度已產生的著法數



/////////////////// Function Prototype /////////////////////////////////////////

// 判斷ptPosition處是否有同一方的子,若有返回true,否則返回false
inline bool HaveFriend( POINT ptPosition, int fSide );

// 判斷 x, y 處是否有同一方的子,若有返回true,否則返回false
inline bool HaveFriend( BYTE x, BYTE y, int fSide );

// 判斷ptPosition處是否有子,若有返回true,否則返回false
inline bool HaveMan( POINT ptPosition );

// 判斷 x, y 處是否有子,若有返回true,否則返回false
inline bool HaveMan( BYTE x, BYTE y );

// 檢查將帥是否碰面,若碰面返回對方王的 y 值坐標,不碰面則返回-1。
//  其中x, y分別為當前走棋方的王所在位置坐標,fSide為當前走棋方
int IsKingFaceToFace( int x, int y, int fSide );

// 產生fSide方所有著法,返回產生的著法總數。nDepth為當前搜索深度,用于傳給AddMoveToQueue函數
int GenerateMove( int fSide, int nDepth );

// 將產生的著法加入著法隊列。nDepth為當前搜索深度
inline void AddMoveToQueue( POINT ptFrom, POINT ptTo, int nDepth );

// 將產生的著法加入著法隊列。nDepth為當前搜索深度
inline void AddMoveToQueue( POINT ptFrom, BYTE x, BYTE y, int nDepth );



////////////////// Programmer-Defined Function //////////////////////////////////

inline bool HaveFriend( POINT ptPosition, int fSide )
{
	if( CChessBoard[ptPosition.x][ptPosition.y] == 0 )
		return false;
	else if( SideOfMan[ CChessBoard[ptPosition.x][ptPosition.y] ] == fSide )
		return true;
	else
		return false;
}

inline bool HaveFriend( BYTE x, BYTE y, int fSide )
{
	if( CChessBoard[x][y] == 0 )
		return false;
	else if( SideOfMan[ CChessBoard[x][y] ] == fSide )
		return true;
	else
		return false;
}

inline bool HaveMan( POINT ptPosition )
{
	if( CChessBoard[ptPosition.x][ptPosition.y] == 0 )
		return false;
	else
		return true;
}

inline bool HaveMan( BYTE x, BYTE y )
{
	if( CChessBoard[x][y] == 0 )
		return false;
	else
		return true;
}

int IsKingFaceToFace( int x, int y, int fSide )
{
	bool bMayKingFaceToFace = false;
	int i, j ;

	if( fSide == RED )
	{
		for( i = 9; i >= 7; i -- )	// 檢查黑將是否在同列
		{
			if(  CChessBoard[x][i] == BLACK_K )
			{
				bMayKingFaceToFace = true;
				break;
			}
		}

		if( bMayKingFaceToFace == false )
			return -1;
			
		for( j = y + 1; j <= i - 1 ; j ++ )	// 黑將在同列,檢查中間是否有隔擋
		{
			if( CChessBoard[x][j] != 0 )	// 有其他子
				return -1;
		}

		return i;	// 將帥碰面,返回黑將的 y 值坐標
	}
	else // fSide == BLACK
	{
		for( i = 0; i <= 2; i ++ )	// 檢查紅帥是否在同列
		{
			if(  CChessBoard[x][i] == RED_K )
			{
				bMayKingFaceToFace = true;
				break;
			}
		}

		if( bMayKingFaceToFace == false )
			return -1;

		for( j = y - 1; j >= i + 1 ; j -- )	// 紅帥在同列,檢查中間是否有隔擋
		{
			if( CChessBoard[x][j] != 0 )	// 有其他子
				return -1;
		}

		return i;	// 將帥碰面,返回紅帥的 y 值坐標
	}

}

int GenerateMove( int fSide, int nDepth )
{
	BYTE    nCChessID ;
	POINT	ptFrom , ptTo , ptHalf ;
	int i;
	
	nMoveCount = 0;

	int x, y;
	for( x = 0; x <= 8; x ++ )
		for( y = 0; y <= 9; y ++ )
		{
			if( CChessBoard[x][y] != 0 )
			{
				nCChessID = CChessBoard[x][y];
				if( SideOfMan[ nCChessID ] != fSide )	//該子顏色與所要生成著法的顏色不同
					continue;

				ptFrom.x = x ;
				ptFrom.y = y ;

				switch( nCChessID )
				{

//==========生成紅帥的著法
				case RED_K:

					// 將帥碰面
					i = IsKingFaceToFace( ptFrom.x, ptFrom.y, fSide );
					if( i != -1 )
						AddMoveToQueue( ptFrom, ptFrom.x, i, nDepth );

					//縱向
					ptTo.x = ptFrom.x ;
					
					//向前
					ptTo.y = ptFrom.y + 1 ;
					if(( ptTo.y <= 2 ) && ( ! HaveFriend( ptTo, fSide ) ))
						AddMoveToQueue( ptFrom, ptTo, nDepth );

					//向后
					ptTo.y = ptFrom.y - 1 ;
					if(( ptTo.y >= 0 ) && ( ! HaveFriend( ptTo, fSide ) ))
						AddMoveToQueue( ptFrom, ptTo, nDepth );

					//橫向
					ptTo.y = ptFrom.y ;

					//向左
					ptTo.x = ptFrom.x - 1 ;
					if(( ptTo.x >= 3 ) && ( ! HaveFriend( ptTo, fSide ) )
						&& ( IsKingFaceToFace( ptTo.x, ptTo.y, fSide ) == -1 ) )
						AddMoveToQueue( ptFrom, ptTo, nDepth );

					//向右
					ptTo.x = ptFrom.x + 1 ;
					if(( ptTo.x <= 5 ) && ( ! HaveFriend( ptTo, fSide ) )
						&& ( IsKingFaceToFace( ptTo.x, ptTo.y, fSide ) == -1 ) )
						AddMoveToQueue( ptFrom, ptTo, nDepth );

					break;


//==========生成黑將的著法
				case BLACK_K:

					// 將帥碰面
					i = IsKingFaceToFace( ptFrom.x, ptFrom.y, fSide );
					if( i != -1 )
						AddMoveToQueue( ptFrom, ptFrom.x, i, nDepth );
					
					//縱向
					ptTo.x = ptFrom.x ;

					//向前
					ptTo.y = ptFrom.y - 1 ;
					if(( ptTo.y >= 7 ) && ( ! HaveFriend( ptTo, fSide ) ))
						AddMoveToQueue( ptFrom, ptTo, nDepth );

					//向后
					ptTo.y = ptFrom.y + 1 ;
					if(( ptTo.y <= 9 ) && ( ! HaveFriend( ptTo, fSide ) ))
						AddMoveToQueue( ptFrom, ptTo, nDepth );

					//橫向
					ptTo.y = ptFrom.y ;

					//向左
					ptTo.x = ptFrom.x + 1 ;
					if(( ptTo.x <= 5 ) && ( ! HaveFriend( ptTo, fSide ) )
						&& ( IsKingFaceToFace( ptTo.x, ptTo.y, fSide ) == -1 ) )
						AddMoveToQueue( ptFrom, ptTo, nDepth );

					//向右
					ptTo.x = ptFrom.x - 1 ;
					if(( ptTo.x >= 3 ) && ( ! HaveFriend( ptTo, fSide ) )
						&& ( IsKingFaceToFace( ptTo.x, ptTo.y, fSide ) == -1 ) )
						AddMoveToQueue( ptFrom, ptTo, nDepth );

					break;


//==========生成紅車的著法
				case RED_J:	
					
					//縱向
					ptTo.x = ptFrom.x ;

					//向前
					for( ptTo.y = ptFrom.y + 1; ptTo.y <= 9; ptTo.y ++ )
					{
						if( HaveMan( ptTo ) )
						{
							if( ! HaveFriend( ptTo, fSide ) )
								AddMoveToQueue( ptFrom, ptTo, nDepth );

							break;
						}
						AddMoveToQueue( ptFrom, ptTo, nDepth );
					}

					//向后
					for( ptTo.y = ptFrom.y - 1; ptTo.y >= 0; ptTo.y -- )
					{
						if( HaveMan( ptTo ) )
						{
							if( ! HaveFriend( ptTo, fSide ) )
								AddMoveToQueue( ptFrom, ptTo, nDepth );

							break;
						}
						AddMoveToQueue( ptFrom, ptTo, nDepth );
					}

					//橫向
					ptTo.y = ptFrom.y ;

					//向左
					for( ptTo.x = ptFrom.x - 1; ptTo.x >= 0; ptTo.x -- )
					{
						if( HaveMan( ptTo ) )
						{
							if( ! HaveFriend( ptTo, fSide ) )
								AddMoveToQueue( ptFrom, ptTo, nDepth );

							break;
						}
						AddMoveToQueue( ptFrom, ptTo, nDepth );
					}

					//向右
					for( ptTo.x = ptFrom.x + 1; ptTo.x <= 8; ptTo.x ++ )
					{
						if( HaveMan( ptTo ) )
						{
							if( ! HaveFriend( ptTo, fSide ) )
								AddMoveToQueue( ptFrom, ptTo, nDepth );

							break;
						}
						AddMoveToQueue( ptFrom, ptTo, nDepth );
					}

					break;


//==========生成黑車的著法
				case BLACK_J:
					
					//縱向
					ptTo.x = ptFrom.x ;

					//向前
					for( ptTo.y = ptFrom.y - 1; ptTo.y >= 0; ptTo.y -- )
					{
						if( HaveMan( ptTo ) )
						{
							if( ! HaveFriend( ptTo, fSide ) )
								AddMoveToQueue( ptFrom, ptTo, nDepth );

							break;
						}
						AddMoveToQueue( ptFrom, ptTo, nDepth );
					}

					//向后
					for( ptTo.y = ptFrom.y + 1; ptTo.y <= 9; ptTo.y ++ )
					{
						if( HaveMan( ptTo ) )
						{
							if( ! HaveFriend( ptTo, fSide ) )
								AddMoveToQueue( ptFrom, ptTo, nDepth );

							break;
						}
						AddMoveToQueue( ptFrom, ptTo, nDepth );
					}


					//橫向
					ptTo.y = ptFrom.y ;

					//向左
					for( ptTo.x = ptFrom.x + 1; ptTo.x <= 8; ptTo.x ++ )
					{
						if( HaveMan( ptTo ) )
						{
							if( ! HaveFriend( ptTo, fSide ) )
								AddMoveToQueue( ptFrom, ptTo, nDepth );

							break;
						}
						AddMoveToQueue( ptFrom, ptTo, nDepth );
					}

					//向右
					for( ptTo.x = ptFrom.x - 1; ptTo.x >= 0; ptTo.x -- )
					{
						if( HaveMan( ptTo ) )
						{
							if( ! HaveFriend( ptTo, fSide ) )
								AddMoveToQueue( ptFrom, ptTo, nDepth );

							break;
						}
						AddMoveToQueue( ptFrom, ptTo, nDepth );
					}

					break;


//==========生成紅馬的著法
				case RED_M:
					
					//ptHalf用來存儲馬腿的位置,以判斷該位置是否有子憋馬腿

					ptHalf.x = ptFrom.x ;
					ptHalf.y = ptFrom.y + 1 ;
					if( ptHalf.y <= 8 && ! HaveMan( ptHalf ) )
					{
						//11點方向
						ptTo.x = ptFrom.x - 1 ;
						ptTo.y = ptFrom.y + 2 ;
						if( ptTo.x >= 0 && ! HaveFriend( ptTo, fSide ) )
							AddMoveToQueue( ptFrom, ptTo, nDepth );

						//1點方向
						ptTo.x = ptFrom.x + 1 ;
						ptTo.y = ptFrom.y + 2 ;
						if( ptTo.x <= 8 && ! HaveFriend( ptTo, fSide ) )
							AddMoveToQueue( ptFrom, ptTo, nDepth );
					}

					ptHalf.x = ptFrom.x + 1 ;
					ptHalf.y = ptFrom.y ;
					if( ptHalf.x <= 7 && ! HaveMan( ptHalf ) )
					{
						//2點方向
						ptTo.x = ptFrom.x + 2 ;
						ptTo.y = ptFrom.y + 1 ;
						if( ptTo.y <= 9 && ! HaveFriend( ptTo, fSide ) )
							AddMoveToQueue( ptFrom, ptTo, nDepth );

						//4點方向
						ptTo.x = ptFrom.x + 2 ;
						ptTo.y = ptFrom.y - 1 ;
						if( ptTo.y >= 0 && ! HaveFriend( ptTo, fSide ) )
							AddMoveToQueue( ptFrom, ptTo, nDepth );
					}

					ptHalf.x = ptFrom.x ;
					ptHalf.y = ptFrom.y - 1 ;
					if( ptHalf.y >= 1 && ! HaveMan( ptHalf ) )
					{
						//5點方向
						ptTo.x = ptFrom.x + 1 ;
						ptTo.y = ptFrom.y - 2 ;
						if( ptTo.x <= 8 && ! HaveFriend( ptTo, fSide ) )
							AddMoveToQueue( ptFrom, ptTo, nDepth );

						//7點方向
						ptTo.x = ptFrom.x - 1 ;
						ptTo.y = ptFrom.y - 2 ;
						if( ptTo.x >= 0 && ! HaveFriend( ptTo, fSide ) )
							AddMoveToQueue( ptFrom, ptTo, nDepth );
					}

					ptHalf.x = ptFrom.x - 1 ;
					ptHalf.y = ptFrom.y ;
					if( ptHalf.x >= 1 && ! HaveMan( ptHalf ) )
					{
						//8點方向
						ptTo.x = ptFrom.x - 2 ;
						ptTo.y = ptFrom.y - 1 ;
						if( ptTo.y >= 0 && ! HaveFriend( ptTo, fSide ) )
							AddMoveToQueue( ptFrom, ptTo, nDepth );

						//10點方向
						ptTo.x = ptFrom.x - 2 ;
						ptTo.y = ptFrom.y + 1 ;
						if( ptTo.y <= 9 && ! HaveFriend( ptTo, fSide ) )
							AddMoveToQueue( ptFrom, ptTo, nDepth );
					}

					break;


//==========生成黑馬的著法
				case BLACK_M:
					
					//ptHalf用來存儲馬腿的位置,以判斷該位置是否有子憋馬腿

					ptHalf.x = ptFrom.x ;
					ptHalf.y = ptFrom.y + 1 ;
					if( ptHalf.y <= 8 && ! HaveMan( ptHalf ) )
					{
						//5點方向
						ptTo.x = ptFrom.x - 1 ;
						ptTo.y = ptFrom.y + 2 ;
						if( ptTo.x >= 0 && ! HaveFriend( ptTo, fSide ) )
							AddMoveToQueue( ptFrom, ptTo, nDepth );

						//7點方向
						ptTo.x = ptFrom.x + 1 ;
						ptTo.y = ptFrom.y + 2 ;
						if( ptTo.x <= 8 && ! HaveFriend( ptTo, fSide ) )
							AddMoveToQueue( ptFrom, ptTo, nDepth );
					}

					ptHalf.x = ptFrom.x + 1 ;
					ptHalf.y = ptFrom.y ;
					if( ptHalf.x <= 7 && ! HaveMan( ptHalf ) )
					{
						//8點方向
						ptTo.x = ptFrom.x + 2 ;
						ptTo.y = ptFrom.y + 1 ;
						if( ptTo.y <= 9 && ! HaveFriend( ptTo, fSide ) )
							AddMoveToQueue( ptFrom, ptTo, nDepth );

						//10點方向
						ptTo.x = ptFrom.x + 2 ;
						ptTo.y = ptFrom.y - 1 ;
						if( ptTo.y >= 0 && ! HaveFriend( ptTo, fSide ) )
							AddMoveToQueue( ptFrom, ptTo, nDepth );
					}

					ptHalf.x = ptFrom.x ;
					ptHalf.y = ptFrom.y - 1 ;
					if( ptHalf.y >= 1 && ! HaveMan( ptHalf ) )
					{
						//11點方向
						ptTo.x = ptFrom.x + 1 ;
						ptTo.y = ptFrom.y - 2 ;
						if( ptTo.x <= 8 && ! HaveFriend( ptTo, fSide ) )
							AddMoveToQueue( ptFrom, ptTo, nDepth );

						//1點方向
						ptTo.x = ptFrom.x - 1 ;
						ptTo.y = ptFrom.y - 2 ;
						if( ptTo.x >= 0 && ! HaveFriend( ptTo, fSide ) )
							AddMoveToQueue( ptFrom, ptTo, nDepth );
					}

					ptHalf.x = ptFrom.x - 1 ;
					ptHalf.y = ptFrom.y ;
					if( ptHalf.x >= 1 && ! HaveMan( ptHalf ) )
					{
						//2點方向
						ptTo.x = ptFrom.x - 2 ;
						ptTo.y = ptFrom.y - 1 ;
						if( ptTo.y >= 0 && ! HaveFriend( ptTo, fSide ) )
							AddMoveToQueue( ptFrom, ptTo, nDepth );

						//4點方向
						ptTo.x = ptFrom.x - 2 ;
						ptTo.y = ptFrom.y + 1 ;
						if( ptTo.y <= 9 && ! HaveFriend( ptTo, fSide ) )
							AddMoveToQueue( ptFrom, ptTo, nDepth );
					}

					break;


//==========生成紅炮的著法
				case RED_P:

					//ptHalf用來存儲炮是否有隔子打子的中間子

					//縱向
					ptTo.x = ptFrom.x ;

					//向前
					ptHalf.x = -1;	//標志尚未發現中間子
					for( ptTo.y = ptFrom.y + 1; ptTo.y <= 9; ptTo.y ++ )
					{
						if( ptHalf.x == -1 ) // 無中間子
						{
							if( ! HaveMan( ptTo ) )
							{
								AddMoveToQueue( ptFrom, ptTo, nDepth );
							}
							else // if( HaveMan( ptTo ) )

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
成人毛片视频在线观看| 在线不卡中文字幕| 欧美日韩免费视频| 国产午夜久久久久| 日本sm残虐另类| 欧美亚洲国产怡红院影院| 国产日韩三级在线| 日日骚欧美日韩| 日本高清免费不卡视频| 国产亚洲欧美日韩俺去了| 亚洲电影视频在线| 99精品久久只有精品| 欧美国产精品一区| 日日夜夜一区二区| 欧美日韩视频在线观看一区二区三区| 国产精品美女久久久久久2018| 男女男精品视频网| 欧美日韩美少妇| 一区二区理论电影在线观看| 国产成人av电影在线播放| 欧美成人一区二区三区片免费 | 欧美日免费三级在线| 欧美色倩网站大全免费| 精品一区二区在线视频| 91麻豆精品国产91久久久久久久久 | 91亚洲国产成人精品一区二三| 日韩欧美久久一区| 免费不卡在线视频| 91精品在线观看入口| 午夜精品在线看| 欧美丰满少妇xxxxx高潮对白| 亚洲一二三区在线观看| 欧美日韩免费电影| 视频精品一区二区| 精品少妇一区二区三区视频免付费 | 国产一区在线精品| 久久久久国产精品免费免费搜索| 精品一区二区精品| www国产成人免费观看视频 深夜成人网| 久久精品久久99精品久久| 日韩午夜av电影| 国产乱码精品1区2区3区| 久久精品在线免费观看| 成人午夜伦理影院| 亚洲欧洲成人精品av97| 91国内精品野花午夜精品| 亚洲成人一二三| 精品毛片乱码1区2区3区| 国产高清亚洲一区| 亚洲男人的天堂网| 欧美一二三区精品| 国产福利一区二区三区| 亚洲日本一区二区| 欧美日产国产精品| 国产一区二区不卡老阿姨| 中文字幕一区二区三区不卡 | 久久电影网电视剧免费观看| 亚洲精品一区二区三区在线观看| 高潮精品一区videoshd| 亚洲精品欧美专区| 欧美日韩不卡在线| 国产成人超碰人人澡人人澡| 中文字幕一区二区三区蜜月| 欧美老女人在线| 国产成人精品综合在线观看| 亚洲欧美激情小说另类| 91精品久久久久久蜜臀| 丁香婷婷综合激情五月色| 亚洲v中文字幕| 久久久久久久久99精品| 欧美日韩国产高清一区| 成人妖精视频yjsp地址| 天天操天天综合网| 国产精品免费免费| 日韩精品一区二区三区老鸭窝 | 波多野结衣视频一区| 亚洲国产成人av好男人在线观看| 欧美不卡在线视频| 在线免费不卡视频| 亚洲国产精品二十页| 麻豆精品一二三| 91国偷自产一区二区三区成为亚洲经典 | 欧美中文字幕一区二区三区亚洲 | 青青草国产精品亚洲专区无| 中文字幕在线观看一区| 久久影院电视剧免费观看| 欧美日韩在线播放一区| 成人avav在线| 国产精品99久久久久久似苏梦涵 | 一区二区不卡在线视频 午夜欧美不卡在 | 亚洲一区二区三区四区五区黄| 国产夜色精品一区二区av| 欧美一区二区日韩| 欧美日韩国产精品成人| 欧美自拍丝袜亚洲| 色吧成人激情小说| 99久久精品国产导航| 国产91精品在线观看| 精品在线观看免费| 蜜桃av一区二区| 丝袜美腿亚洲一区二区图片| 一区二区三区产品免费精品久久75| 91.com视频| 亚洲一区日韩精品中文字幕| 26uuu久久天堂性欧美| 欧美日韩激情一区二区| 91极品视觉盛宴| 在线观看不卡一区| 在线观看亚洲成人| 在线观看91精品国产入口| 91免费国产在线观看| 亚洲综合激情网| 88在线观看91蜜桃国自产| 色悠久久久久综合欧美99| 成人av资源下载| 成人激情校园春色| 成人激情小说网站| 成人在线综合网| 国产不卡视频在线播放| 国产精品伊人色| 国产精品18久久久久久久久| 国产一区视频导航| 国产乱子轮精品视频| 国产精一区二区三区| 国产成人av一区| a在线欧美一区| 91久久精品一区二区二区| 色狠狠av一区二区三区| 欧美群妇大交群中文字幕| 51精品视频一区二区三区| 日韩视频中午一区| 久久久久久免费网| 亚洲欧美激情在线| 亚洲成a人片在线不卡一二三区| 亚洲一区二区三区国产| 亚洲第一会所有码转帖| 日本伊人色综合网| 国内精品视频一区二区三区八戒| 精品亚洲国内自在自线福利| 福利一区二区在线| 色av综合在线| 91精品国产综合久久精品麻豆 | 国产精品欧美一区喷水| 亚洲精品国产一区二区三区四区在线 | 欧美在线不卡一区| 日韩一区二区视频| 日本一区二区高清| 亚洲综合色在线| 国产精品一区二区你懂的| 91在线观看视频| 欧美大度的电影原声| 国产欧美日本一区二区三区| 亚洲永久精品大片| 国产黄色精品视频| 在线播放中文字幕一区| 国产精品天干天干在观线| 日韩国产在线观看一区| 99re这里只有精品视频首页| 欧美大片日本大片免费观看| 亚洲欧美色一区| 国产精品一区不卡| 88在线观看91蜜桃国自产| 中文字幕一区二区三区四区| 免费精品视频在线| 在线一区二区三区做爰视频网站| 精品国产自在久精品国产| 亚洲综合久久av| jlzzjlzz亚洲女人18| 精品美女在线播放| 亚洲成a人v欧美综合天堂| 91在线精品一区二区三区| 日韩欧美国产一区二区在线播放| 一区二区三区在线视频免费| 国产成人精品影院| 欧美精品一区二区精品网| 亚洲国产精品久久艾草纯爱| 91免费视频大全| 国产欧美日本一区视频| 国产综合成人久久大片91| 欧美电影在哪看比较好| 夜夜嗨av一区二区三区网页| 99视频超级精品| 中文字幕亚洲一区二区va在线| 国产一区二区三区黄视频| 精品黑人一区二区三区久久| 日韩精品一卡二卡三卡四卡无卡| 91久久线看在观草草青青| 亚洲天堂a在线| www.视频一区| 亚洲图片你懂的| 一本久久a久久免费精品不卡| 国产蜜臀av在线一区二区三区| 玖玖九九国产精品| 26uuu成人网一区二区三区| 蜜桃在线一区二区三区| 欧美成人精精品一区二区频| 毛片一区二区三区| 精品美女一区二区| 国产成人av电影免费在线观看| 欧美激情中文字幕一区二区|