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

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關(guān)于我們
? 蟲蟲下載站

?? searchengine.java

?? 一個(gè)網(wǎng)絡(luò)對(duì)弈的中國象棋程序 操作: 1、Setting,選擇對(duì)戰(zhàn)方式。如果選擇“網(wǎng)絡(luò)對(duì)戰(zhàn)”
?? JAVA
?? 第 1 頁 / 共 2 頁
字號(hào):
/*
 * 創(chuàng)建日期 2005-3-18
 *
 * 更改所生成文件模板為
 * 窗口 > 首選項(xiàng) > Java > 代碼生成 > 代碼和注釋
 */
package org.acerge.engine;

import java.io.BufferedReader;
import java.io.BufferedWriter;
import java.io.FileReader;
import java.io.FileWriter;
import java.io.IOException;
import java.io.RandomAccessFile;
import java.util.Calendar;
import java.util.Random;

import org.apache.commons.logging.*;
public class SearchEngine {
	private static Log log = LogFactory.getLog( SearchEngine.class );
	public static final int MaxBookMove = 40;//使用開局庫的最大步數(shù)
	public static final int MaxKiller = 4;//搜索殺著的最大步數(shù)
	private static final int BookUnique = 1;//指示結(jié)點(diǎn)類型,下同
	private static final int BookMulti = 2;
	private static final int HashAlpha = 4;
	private static final int HashBeta = 8;
	private static final int HashPv = 16;

	private static final int ObsoleteValue = -CCEvalue.MaxValue - 1;
	private static final int UnknownValue = -CCEvalue.MaxValue - 2;
	//private static final int BookUniqueValue = CCEvalue.MaxValue + 1;
	//private static final int BookMultiValue = CCEvalue.MaxValue + 2;//推薦使用開局庫,值要足夠大
	
	public static final int CLOCK_S = 1000;//1秒=1000毫秒
	public static final int CLOCK_M = 1000*60;//1分=60秒
	private static final Random rand = new Random();
	private MoveNode bestMove=null;

	//for search control
	private int depth;
	private long properTimer, limitTimer;
	// 搜索過程的全局變量,包括:
	// 1. 搜索樹和歷史表

	private ActiveBoard activeBoard;
	private int histTab[][];
	public void setActiveBoard(ActiveBoard activeBoard){
		this.activeBoard=activeBoard;
	}
	// 2. 搜索選項(xiàng)
	private int selectMask,style;//下棋風(fēng)格 default = EngineOption.Normal;
	private boolean wideQuiesc, futility, nullMove;
	//SelectMask:隨機(jī)性 , WideQuiesc(保守true if Style == EngineOption.solid) 
	//Futility(true if Style == EngineOption.risky冒進(jìn))
	//NullMove 是否空著剪裁 
	private boolean ponder;
	// 3. 時(shí)間控制參數(shù)
	private long startTimer, minTimer, maxTimer;
	private int startMove;
	private boolean stop;
	// 4. 統(tǒng)計(jì)信息:Main Search Nodes, Quiescence Search Nodes and Hash Nodes
	private int nodes, nullNodes, hashNodes, killerNodes, betaNodes, pvNodes, alphaNodes, mateNodes, leafNodes;
	private int quiescNullNodes, quiescBetaNodes, quiescPvNodes, quiescAlphaNodes, quiescMateNodes;
	private int hitBeta, hitPv, hitAlpha;
	// 5. 搜索結(jié)果
	private int lastScore, pvLineNum;
	private MoveNode pvLine[]=new MoveNode[ActiveBoard.MAX_MOVE_NUM];

	// 6. Hash and Book Structure
	private int hashMask, maxBookPos, bookPosNum;
	private HashRecord[] hashList;
	private BookRecord[] bookList;
	public SearchEngine(ActiveBoard chessP){
		this();
		activeBoard = chessP;
	}
	public SearchEngine(){
		int i;
		//Position = new ChessPosition();
		histTab=new int[90][90];;
		nodes=nullNodes=hashNodes=killerNodes=betaNodes=pvNodes=alphaNodes=mateNodes=leafNodes=0;
		selectMask=0;//1<<10-1;//隨機(jī)性
		style=EngineOption.Normal;
		wideQuiesc=style==EngineOption.Solid;
		futility=style==EngineOption.Risky;
		nullMove=true;
		// Search results
		lastScore=0; pvLineNum=0;
		MoveNode PvLine[]=new MoveNode[ActiveBoard.MAX_MOVE_NUM];
		for (i=0;i < ActiveBoard.MAX_MOVE_NUM;i++){
			PvLine[i]=new MoveNode();
		}
		newHash(17,14);
		depth = 8; properTimer = CLOCK_M * 1 ; limitTimer = CLOCK_M *20;	
	}
	
	//Begin History and Hash Table Procedures
	public void newHash(int HashScale, int BookScale) {
		histTab = new int[90][90];
		hashMask = (1 << HashScale) - 1;
		maxBookPos = 1 << BookScale;
		hashList = new HashRecord[hashMask+1];
		for (int i=0; i< hashMask+1; i++){
			hashList[i]=new HashRecord();
		}
		bookList = new BookRecord[maxBookPos];
		//for (int i=0; i< MaxBookPos; i++){
		//	BookList[i]=new BookRecord();
		//}

		clearHistTab();
		clearHash();
		//BookRand = rand.nextLong();//(unsigned long) time(NULL);
	}
	public void delHash() {
		histTab=null;
		hashList=null;
		bookList=null;
	}

	public void clearHistTab() {
		int i, j;
		for (i = 0; i < 90; i ++) {
			for (j = 0; j < 90; j ++) {
				histTab[i][j] = 0;
			}
		}		
	}

	public void clearHash() {
		int i;
		for (i = 0; i <= hashMask; i ++) {
			hashList[i].flag = 0;
		}
	}

	private int probeHash(MoveNode HashMove, int Alpha, int Beta, int Depth) {
		boolean MateNode;
		HashRecord TempHash;
		int tmpInt = (int) (activeBoard.getZobristKey() & hashMask);
		long tmpLong1 = activeBoard.getZobristLock(),tmpLong2;
		TempHash = hashList[(int) (activeBoard.getZobristKey() & hashMask)];
		tmpLong2 = TempHash.zobristLock;
		if (TempHash.flag!=0 && TempHash.zobristLock == activeBoard.getZobristLock()) {
			MateNode = false;
			if (TempHash.value > CCEvalue.MaxValue - ActiveBoard.MAX_MOVE_NUM / 2) {
				TempHash.value -= activeBoard.getMoveNum() - startMove;
				MateNode = true;
			} else if (TempHash.value < ActiveBoard.MAX_MOVE_NUM / 2 - CCEvalue.MaxValue) {
				TempHash.value += activeBoard.getMoveNum() - startMove;
				MateNode = true;
			}
			if (MateNode || TempHash.depth >= Depth) {
				if ((TempHash.flag & HashBeta)!=0) {
					if (TempHash.value >= Beta) {
						hitBeta ++;
						return TempHash.value;
					}
				} else if ((TempHash.flag & HashAlpha)!=0) {
					if (TempHash.value <= Alpha) {
						hitAlpha ++;
						return TempHash.value;
					}
				} else if ((TempHash.flag & HashPv)!=0) {
					hitPv ++;
					return TempHash.value;
				} else {
					return UnknownValue;
				}
			} 
			if (TempHash.bestMove.src == -1) {
				return UnknownValue;
			} else {
				HashMove = TempHash.bestMove;
				return ObsoleteValue;
			}
		}
		return UnknownValue;
	}

	private void recordHash(MoveNode hashMove, int hashFlag, int value, int depth) {
		HashRecord tempHash;
		tempHash = hashList[(int) (activeBoard.getZobristKey() & hashMask)];
		if ((tempHash.flag!=0) && tempHash.depth > depth) {
			return;
		}
		tempHash.zobristLock = activeBoard.getZobristLock();
		tempHash.flag = hashFlag;
		tempHash.depth = depth;
		tempHash.value =  value;
		if (tempHash.value > CCEvalue.MaxValue - ActiveBoard.MAX_MOVE_NUM / 2) {
			tempHash.value += activeBoard.getMoveNum() - startMove;
		} else if (tempHash.value < ActiveBoard.MAX_MOVE_NUM / 2 - CCEvalue.MaxValue) {
			tempHash.value -= activeBoard.getMoveNum() - startMove;
		}
		tempHash.bestMove = hashMove;
		hashList[(int) (activeBoard.getZobristKey() & hashMask)] = tempHash;
	}

	private void GetPvLine() {
		HashRecord tempHash;
		tempHash = hashList[(int) (activeBoard.getZobristKey() & hashMask)];
		if ((tempHash.flag!=0) && tempHash.bestMove.src != -1 && tempHash.zobristLock == activeBoard.getZobristLock()) {
			pvLine[pvLineNum] = tempHash.bestMove;
			activeBoard.movePiece(tempHash.bestMove);
			pvLineNum ++;
			if (activeBoard.isLoop(1)==0) {//???????
				GetPvLine();
			}
			activeBoard.undoMove();
		}
	}

//	record example: i0h0 4 rnbakabr1/9/4c1c1n/p1p1N3p/9/6p2/P1P1P3P/2N1C2C1/9/R1BAKAB1R w - - 0 7
//	i0h0:Move , 4: evalue, other: FEN String

	public void loadBook(final String bookFile) throws IOException{//開局庫
		int bookMoveNum, value ,i;
		BufferedReader inFile;
		String lineStr;
		// LineStr;
		int index=0;
		MoveNode bookMove=new MoveNode();//note:wrong
		HashRecord tempHash;
		ActiveBoard BookPos=new ActiveBoard();//note:wrong
		inFile = new BufferedReader(new FileReader(bookFile),1024*1024);
		if (inFile == null) return;
		bookPosNum = 0;
		int recordedToHash = 0;//for test
		while ((lineStr=inFile.readLine())!=null) {
			bookMove = new MoveNode();
			bookMove.move(lineStr);
			index=0;
			if (bookMove.src != -1) {
				index += 5;
				while(lineStr.charAt(index)==' '){
					index++;
				}
				BookPos.loadFen(lineStr.substring(index));
				long tmpZob = BookPos.getZobristKey();
				int tmp = BookPos.getSquares(bookMove.src);//for test
				if (BookPos.getSquares(bookMove.src)!=0) {
					tempHash = hashList[(int) (BookPos.getZobristKey() & hashMask)];
					if (tempHash.flag!=0) {//占用
						if (tempHash.zobristLock == BookPos.getZobristLock()){//局面相同
							if ((tempHash.flag & BookMulti)!=0) {//多個(gè)相同走法
								bookMoveNum = bookList[tempHash.value].moveNum;
								if (bookMoveNum < MaxBookMove) {
									bookList[tempHash.value].moveList[bookMoveNum] = bookMove;
									bookList[tempHash.value].moveNum ++;
									recordedToHash++;//for test
								}
							}else{
								if(bookPosNum < maxBookPos) {
									tempHash.flag = BookMulti;
									bookList[bookPosNum] = new BookRecord();
									bookList[bookPosNum].moveNum = 2;
									bookList[bookPosNum].moveList[0] = tempHash.bestMove;
									bookList[bookPosNum].moveList[1] = bookMove;
									tempHash.value = bookPosNum;
									bookPosNum ++;
									hashList[(int) (BookPos.getZobristKey() & hashMask)] = tempHash;
									recordedToHash++;//for test
								}
							}
						}
					} else {
						tempHash.zobristLock = BookPos.getZobristLock();
						tempHash.flag = BookUnique;
						tempHash.depth = 0;
						tempHash.value = 0;
						tempHash.bestMove = bookMove;
						hashList[(int) (BookPos.getZobristKey() & hashMask)] = tempHash;
						recordedToHash++;
					}
				}
			}
		}
		inFile.close();		
	}

//	End History and Hash Tables Procedures

//	Begin Search Procedures
	// Search Procedures
	private int RAdapt(int depth) {
		//根據(jù)不同情況來調(diào)整R值的做法,稱為“適應(yīng)性空著裁剪”(Adaptive Null-Move Pruning),
		//它首先由Ernst Heinz發(fā)表在1999年的ICCA雜志上。其內(nèi)容可以概括為
		//a. 深度小于或等于6時(shí),用R = 2的空著裁剪進(jìn)行搜索
		//b. 深度大于8時(shí),用R = 3; 
		//c. 深度是6或7時(shí),如果每方棋子都大于或等于3個(gè),則用 R = 3,否則用 R = 2。

		if (depth <= 6) {
			return 2;
		} else if (depth <= 8) {
			return activeBoard.getEvalue(0) < CCEvalue.EndgameMargin || activeBoard.getEvalue(1) < CCEvalue.EndgameMargin ? 2 : 3;
		} else {
			return 3;
		}
	}
	
	private int quiesc(int Alpha, int Beta) {//只對(duì)吃子
		int i, bestValue, thisAlpha, thisValue;
		boolean inCheck, movable;
		MoveNode thisMove;
		SortedMoveNodes moveSort=new SortedMoveNodes();
		
		// 1. Return if a Loop position is detected
		if (activeBoard.getMoveNum() > startMove) {
			thisValue = activeBoard.isLoop(1);//note:wrong
			if (thisValue!=0) {
				return activeBoard.loopValue(thisValue, activeBoard.getMoveNum() - startMove);
			}
		}
		
		// 2. Initialize
		inCheck = activeBoard.lastMove().chk;
		movable = false;
		bestValue = -CCEvalue.MaxValue;
		thisAlpha = Alpha;

		// 3. For non-check position, try Null-Move before generate moves
		if (!inCheck) {
			movable = true;
			thisValue = activeBoard.evaluation() + (selectMask!=0 ? (rand.nextInt() & selectMask) - (rand.nextInt() & selectMask) : 0);
			if (thisValue > bestValue) {
				if (thisValue >= Beta) {
					quiescNullNodes ++;
					return thisValue;
				}
				bestValue = thisValue;
				if (thisValue > thisAlpha) {
					thisAlpha = thisValue;
				}
			}
		}
		// 4. Generate and sort all moves for check position, or capture moves for non-check position
		moveSort.GenMoves(activeBoard, inCheck ? histTab : null);
		for (i = 0; i < moveSort.MoveNum; i ++) {
			moveSort.BubbleSortMax(i);
			thisMove = moveSort.MoveList[i];
			if (inCheck || activeBoard.narrowCap(thisMove, wideQuiesc)) {
				if (activeBoard.movePiece(thisMove)) {
					movable = true;
					
					// 5. Call Quiescence Alpha-Beta Search for every leagal moves 
					thisValue = -quiesc(-Beta, -thisAlpha);
					//for debug
					String tmpStr="";
					for (int k=0;k<activeBoard.getMoveNum();k++){
						 tmpStr = tmpStr + activeBoard.moveList[k]+",";
					}
					
					tmpStr = tmpStr+"Value:"+thisValue+"\n";
					activeBoard.undoMove();

					// 6. Select the best move for Fail-Soft Alpha-Beta
					if (thisValue > bestValue) {
						if (thisValue >= Beta) {
							quiescBetaNodes ++;
							return thisValue;
						}
						bestValue = thisValue;
						if (thisValue > thisAlpha) {
							thisAlpha = thisValue;
						}
					}
				}
			}
		}

		// 7. Return a loose value if no leagal moves
		if (!movable) {
			quiescMateNodes ++;
			return activeBoard.getMoveNum() - startMove - CCEvalue.MaxValue;
		}
		if (thisAlpha > Alpha) {
			quiescPvNodes ++;
		} else {
			quiescAlphaNodes ++;
		}
		return bestValue;
	}
	// 搜索算法,包括
	//	1. Hash Table;
	//	2. 超出邊界的Alpha-Beta搜索
	//	3. 適應(yīng)性空著裁減
	//	4. 選擇性擴(kuò)展
	//	5. 使用Hash Table的迭代加深;
	//	6. 殺著表
	//	7. 將軍擴(kuò)展
	//	8. 主要變例搜索
	//	9. 歷史啟發(fā)表
	
	private int search(KillerStruct KillerTab, int Alpha, int Beta, int Depth) {
		int i, j, thisDepth, futPrune, hashFlag;
		boolean inCheck, movable, searched;
		int hashValue, bestValue, thisAlpha, thisValue, futValue=0;
		MoveNode thisMove=new MoveNode();
		MoveNode bestMove=new MoveNode();
		SortedMoveNodes moveSort=new SortedMoveNodes();
		KillerStruct subKillerTab=new KillerStruct();
		// Alpha-Beta Search:
		// 1. 重復(fù)循環(huán)檢測(cè)
		if (activeBoard.getMoveNum() > startMove) {
			thisValue = activeBoard.isLoop(1);//
			if (thisValue!=0) {
				return activeBoard.loopValue(thisValue, activeBoard.getMoveNum() - startMove);
			}
		}
		
		// 2. 是否需要擴(kuò)展
		inCheck = activeBoard.lastMove().chk;
		thisDepth = Depth;
		if (inCheck) {
			thisDepth ++;
		}

		// 3. Return if hit the Hash Table
		hashValue = probeHash(thisMove, Alpha, Beta, thisDepth);
		if (hashValue >= -CCEvalue.MaxValue && hashValue <= CCEvalue.MaxValue) {
			return hashValue;
		}

		// 4. Return if interrupted or timeout
		if (interrupt()) {
			return 0;
		};

		// 5. 正式開始搜索:
		if (thisDepth > 0) {
			movable = false;
			searched = false;
			bestValue = -CCEvalue.MaxValue;
			thisAlpha = Alpha;
			hashFlag = HashAlpha;
			subKillerTab.moveNum = 0;
			
			// 6. 是否需要空著裁減與冒進(jìn)?
			futPrune=0;
			if (futility) {
				// 冒進(jìn) 
				if (thisDepth == 3 && !inCheck && activeBoard.evaluation() + CCEvalue.RazorMargin <= Alpha && activeBoard.getEvalue(activeBoard.getOppPlayer()) > CCEvalue.EndgameMargin) {
					thisDepth = 2;
				}
				if (thisDepth < 3) {
					futValue = activeBoard.evaluation() + (thisDepth == 2 ? CCEvalue.ExtFutMargin : CCEvalue.SelFutMargin);

?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號(hào) Ctrl + =
減小字號(hào) Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
制服视频三区第一页精品| 中文字幕欧美激情一区| 不卡视频在线观看| 免费日本视频一区| 亚洲精品国久久99热| 国产日韩精品一区二区三区| 欧美疯狂性受xxxxx喷水图片| 成人综合婷婷国产精品久久蜜臀| 日韩avvvv在线播放| 一区二区视频在线看| 国产欧美一区视频| 欧美电影免费观看高清完整版在线| 色哟哟一区二区在线观看| 成人午夜视频在线| 国产在线精品一区在线观看麻豆| 日本中文在线一区| 亚洲丰满少妇videoshd| 17c精品麻豆一区二区免费| 国产精品久久三区| 欧美激情综合五月色丁香| 久久综合狠狠综合久久综合88 | 欧美日韩一区二区电影| 9色porny自拍视频一区二区| 国产成人午夜99999| 国内精品视频一区二区三区八戒| 日韩国产欧美视频| 天堂在线亚洲视频| 无码av免费一区二区三区试看 | 欧美aaa在线| 日精品一区二区| 亚洲18女电影在线观看| 亚洲国产日韩在线一区模特| 亚洲自拍另类综合| 亚洲中国最大av网站| 亚洲综合另类小说| 一区二区高清视频在线观看| 一区二区高清免费观看影视大全 | 欧美性色黄大片手机版| 色婷婷国产精品| 91行情网站电视在线观看高清版| 91成人网在线| 欧美人xxxx| 欧美高清www午色夜在线视频| 欧美酷刑日本凌虐凌虐| 欧美一区二区三区在线观看| 日韩欧美成人一区| 久久人人超碰精品| 国产精品人妖ts系列视频| 国产精品美女久久福利网站| 亚洲人成在线播放网站岛国| 亚洲综合激情网| 天使萌一区二区三区免费观看| 视频一区在线播放| 国产在线视频一区二区| 成人精品亚洲人成在线| 色菇凉天天综合网| 51精品国自产在线| 久久综合色综合88| 成人免费在线视频观看| 亚洲国产精品一区二区www | 亚洲视频免费看| 午夜视黄欧洲亚洲| 国产在线国偷精品产拍免费yy | 99re6这里只有精品视频在线观看| 在线免费观看日韩欧美| 日韩一区二区精品在线观看| 国产欧美一二三区| 亚洲线精品一区二区三区| 免费在线视频一区| 成人免费av网站| 欧美日韩亚洲国产综合| 久久综合九色综合欧美亚洲| 自拍偷拍欧美精品| 不卡区在线中文字幕| 欧美性高清videossexo| 久久综合色婷婷| 亚洲一区在线观看免费 | 成人毛片在线观看| 91福利国产成人精品照片| 日韩精品在线一区| 成人免费视频在线观看| 美女脱光内衣内裤视频久久网站| 国产福利一区二区三区视频在线 | 99久久久久久| 日韩欧美一二三四区| 日韩理论在线观看| 麻豆精品久久精品色综合| 91浏览器打开| 久久久久高清精品| 天堂一区二区在线| 91丨porny丨中文| wwwwxxxxx欧美| 亚洲成av人片一区二区三区| 成人白浆超碰人人人人| 日韩欧美中文字幕一区| 亚洲精品视频在线观看网站| 国产精品一区二区久久精品爱涩 | 91久久香蕉国产日韩欧美9色| 精品久久久久一区二区国产| 亚洲国产乱码最新视频| 成人高清伦理免费影院在线观看| 日韩一区二区电影在线| 亚洲一区二区三区四区五区中文| 岛国一区二区三区| 久久只精品国产| 青青草国产精品亚洲专区无| 欧美午夜不卡在线观看免费| 国产精品国产馆在线真实露脸 | 91精品国产免费| 亚洲精品第一国产综合野| 国产v日产∨综合v精品视频| 日韩精品一区二区三区在线| 午夜视频在线观看一区二区三区| 色综合久久99| 亚洲啪啪综合av一区二区三区| 国产精品一区二区黑丝| 精品国产自在久精品国产| 天天免费综合色| 欧美视频一区在线观看| 亚洲精品高清视频在线观看| 99国内精品久久| 国产精品福利一区| 成年人国产精品| 国产精品美女一区二区在线观看| 国产九色精品成人porny| 精品裸体舞一区二区三区| 美女在线视频一区| 日韩精品一区二区三区四区视频| 日韩电影在线观看一区| 91精品国产一区二区三区蜜臀| 亚洲福中文字幕伊人影院| 欧美日韩一级二级三级| av电影天堂一区二区在线| 国产欧美一区二区精品性| 国产精品自拍毛片| 中文字幕欧美日本乱码一线二线| 制服丝袜亚洲播放| 成人免费视频caoporn| 精品三级在线观看| 日韩极品在线观看| 91精品国产丝袜白色高跟鞋| 午夜精品视频在线观看| 欧美一区二区视频在线观看| 奇米影视7777精品一区二区| 日韩欧美www| 国产一区二区成人久久免费影院| 久久久久久久久免费| 国产精品一区三区| 国产精品女主播av| 在线视频一区二区三区| 天堂va蜜桃一区二区三区| 日韩精品专区在线| 国产成人午夜高潮毛片| 中文字幕一区二区三区色视频| 色视频欧美一区二区三区| 午夜欧美在线一二页| 日韩精品一区二区三区三区免费 | av高清不卡在线| 一区二区高清免费观看影视大全| 欧美色图第一页| 久久精品国产精品亚洲红杏| 亚洲国产精品成人久久综合一区| 99久久精品国产网站| 午夜精品一区在线观看| 精品国产91久久久久久久妲己| 国产成人免费xxxxxxxx| 一区二区在线观看不卡| 欧美一级片在线| 成人黄色a**站在线观看| 亚洲一区二区三区四区中文字幕| 日韩一区二区精品葵司在线| 国产91在线观看| 性欧美大战久久久久久久久| 精品国产99国产精品| 色噜噜狠狠一区二区三区果冻| 免费在线观看精品| 亚洲图片另类小说| 日韩欧美在线观看一区二区三区| 不卡av在线网| 秋霞国产午夜精品免费视频| 国产精品久久久久影院老司 | 国产suv精品一区二区6| 一区二区高清免费观看影视大全 | 国产精品亚洲а∨天堂免在线| 亚洲欧美日韩电影| 久久综合视频网| 欧美影院精品一区| 丰满少妇久久久久久久| 日韩电影免费在线看| 亚洲人成亚洲人成在线观看图片| 欧美成人性战久久| 欧美日韩一级片网站| a级高清视频欧美日韩| 精品一区二区免费在线观看| 一级女性全黄久久生活片免费| 国产午夜久久久久| 欧美一级片在线观看| 欧美四级电影在线观看| 成人久久18免费网站麻豆| 久久99九九99精品|