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

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

?? confirmnfa.java

?? 本程序是編譯原理的經(jīng)典試驗(yàn)
?? JAVA
?? 第 1 頁(yè) / 共 2 頁(yè)
字號(hào):
	 * @param statusT
	 * @param input
	 * @return
	 */
	public String move(String statusT, int input, String[][] metrix) {
		String afterMove = "";
		for(int i = 0; i < statusT.length(); i++) {
			if(!metrix[statusT.charAt(i) - '0'][input].equals("#") && !metrix[statusT.charAt(i) - '0'][input].equals("@")) {
				afterMove += metrix[statusT.charAt(i) - '0'][input];
			}
		}
		afterMove = removeEcho(afterMove);
		return afterMove;
	}
	/**
	 * 求moveStatus的閉包集,最終存儲(chǔ)在closureStatus
	 * e - closure(move(T, a))
	 * @param moveStatus
	 * @param closureStatus
	 * @param eIndex
	 * @return
	 */
	public String closure(String moveStatus, String closureStatus, int eIndex) {
		for(int i = 0; i < moveStatus.length(); i++) {								/* moveStatus表示move(T, a),已經(jīng)由move函數(shù)求得 */
			String str = matrix_NFA[moveStatus.charAt(i) - '0'][eIndex];	/* 在e輸入下的跳轉(zhuǎn)狀態(tài) */
			if(str.charAt(0) == '#') {
				continue;
			}
			for(int j = 0; j < str.length(); j++) {
				if(closureStatus.contains(String.valueOf(str.charAt(j)))) {
					continue;
				} else {
					closureStatus += str.charAt(j);
				}
				closureStatus = closure(String.valueOf(str.charAt(j)), closureStatus, eIndex);	/* 遞歸求在e輸入下的一連串狀態(tài) */
			}
		}
		return closureStatus;
	}
	/**
	 * NFA的確定化函數(shù)
	 */
	public void confirm() {
		String moveStatus;							/* 存放子集成員在a輸入下的狀態(tài)轉(zhuǎn)換集 */
		String closureStatus;							/* 存放在moveStatus的閉包集 */
		ArrayList strOnly;								/* 存放子集中的元素,與c_Group不同的是strOnly只存放狀態(tài)集,以便判斷 */
		int stTag = 0;									/* 與ClosureStatus類中的ST變量對(duì)應(yīng) */

		moveStatus = closureStatus = "0";	/* 初始值為初始狀態(tài) */		
		closureStatus = sort(closure(moveStatus, closureStatus, len_SYMS));	/* 求初始狀態(tài)的閉包集,并排序 */

		c_Group = new ArrayList();
		strOnly = new ArrayList();
		ClosureStatus cs = new ClosureStatus();											/* 狀態(tài)子集中的第一個(gè)元素,課本算法上的T0集,為標(biāo)記*/
		cs.setSTATUS(closureStatus);
		cs.setST("" + stTag);
		stTag++;
		c_Group.add(cs);																				/* 把T0添加到C子集中 */			
		strOnly.add(closureStatus);
		counter++;									
		
		/**
		 * 
		 * index_CGroup:從C子集開頭挨個(gè)檢測(cè)狀態(tài)集是否被標(biāo)記的下標(biāo)
		 * counter:C子集中的狀態(tài)個(gè)數(shù)
		 * C子集中存在未標(biāo)記的狀態(tài)集且index_CGroup < counter則繼續(xù)執(zhí)行
		 */
		while(index_CGroup < counter && !((ClosureStatus)c_Group.get(index_CGroup)).isTARGET()) {
			cs = (ClosureStatus)c_Group.get(index_CGroup);
			String tempStr = cs.getSTATUS();
			cs.setTARGET(true);
			for(int i = 1; i < len_SYMS; i++) {
				moveStatus = move(tempStr, i, matrix_NFA);								/* 代表move(T, a)*/
				closureStatus = moveStatus;														/* 待求閉包的狀態(tài)集也包含在閉包集中 */
				closureStatus = closure(moveStatus, closureStatus, len_SYMS);	/* 求閉包 */
				closureStatus = removeEcho(closureStatus);								/* 刪除在狀態(tài)集中重復(fù)的狀態(tài) */
				closureStatus = sort(closureStatus);											/* 排序 */
				ClosureStatus newCS = new ClosureStatus();
				newCS.setSTATUS(closureStatus);
				if(!strOnly.contains(closureStatus)) {											/* 如果新求得的閉包集不包含在C子集中,則添加到C子集中 */
					newCS.setST("" +stTag );
					stTag++;
					c_Group.add(newCS);
					strOnly.add(closureStatus);
					counter++;
				}
			}
			index_CGroup++;
		}
		strToChar();
	}
	public void getInitData() {
		String nextLine;									/* 存放從文件中讀取的一行字符串 */
		String tempStr;									/* 存放所讀取字符串去空格之后的字符串 */		
		StringTokenizer tokenStr;					/* 序列化字符串 */
		int tempRow, tempCol;						/* 初始化matrix_NFA矩陣時(shí)的臨時(shí)下標(biāo) */
		int statusIndex;									/* 在矩陣每行最前面標(biāo)記狀態(tài) */

		try {
			BufferedReader br = new BufferedReader(new FileReader("./files/Test.txt"));

			tempStr = "";
			nextLine = br.readLine();					/* 讀取第一行,作為輸入符號(hào)集 */
			tokenStr=new StringTokenizer(nextLine);
			while(tokenStr.hasMoreTokens()) {
				tempStr += tokenStr.nextToken();
			}
			len_SYMS = tempStr.length();			/* 輸入符號(hào)個(gè)數(shù) */
			input_SYM = new char[len_SYMS];	/* 分配輸入符號(hào)數(shù)組長(zhǎng)度 */
			input_SYM = tempStr.toCharArray();	/* 用讀取到的輸入符號(hào)初始化input_SYM內(nèi)的元素 */

			tempStr = "";
			nextLine = br.readLine();					/* 讀取第二行,NFA的終態(tài)集 */
			tokenStr=new StringTokenizer(nextLine);
			while(tokenStr.hasMoreTokens()) {
				tempStr += tokenStr.nextToken();
			}
			len_ENDSTNFA = tempStr.length();					/* NFA的終態(tài)個(gè)數(shù) */
			endStatus_NFA = new char[len_ENDSTNFA];		/* 初始化NFA終態(tài)集的長(zhǎng)度 */
			endStatus_NFA = tempStr.toCharArray();			/* 用所讀取到的終態(tài)初始化endStatus_NFA的元素 */

			nextLine = br.readLine();									/* 讀取地三行,狀態(tài)轉(zhuǎn)換矩陣的行數(shù) */
			row_NFA = Integer.parseInt(nextLine);	
			col_NFA = len_SYMS;	
			matrix_NFA = new String[row_NFA][col_NFA + 1];	/* 分配NFA狀態(tài)轉(zhuǎn)換矩陣空間大小 */

			tempStr = "";
			nextLine = br.readLine();									/* 讀取矩陣 */
			tokenStr=new StringTokenizer(nextLine);
			tempRow = 0;	tempCol = 0;
			statusIndex = 0;
			while(nextLine != null && !nextLine.equals("")) {
				matrix_NFA[tempRow][tempCol++] = "" + statusIndex++;
				while(tokenStr.hasMoreTokens()) {
					matrix_NFA[tempRow][tempCol++] = tokenStr.nextToken();
				}

				nextLine = br.readLine();
				if(nextLine != null && !nextLine.equals("")) {
					tokenStr=new StringTokenizer(nextLine);
				}
				tempRow++;	tempCol = 0;
			}
		} catch(FileNotFoundException e) {
			System.out.println("FileNotFoundException!!!");
		} catch(IOException e) {
			System.out.println("IOException");
		}
	}
	public void display(int n) {
		switch(n) {
		case 1:
			for(int i = 0; i < row_NFA; i++) {
				for(int j = 0; j < col_NFA + 1; j++) {
					System.out.print(matrix_NFA[i][j] + "\t");
				}
				System.out.println();
			}
			break;
		case 2:
			for(int i = 0; i < row_DFA; i++) {
				for(int j = 0; j < col_DFA + 1; j++) {
					System.out.print(matrix_DFA[i][j] + "\t");
				}
				System.out.println();
			}
			break;
		}
	}
	public void check() {
		String inputStr = "";
		int next = 0;
		String status = "0";

		try {
			BufferedReader br = new BufferedReader(new InputStreamReader(System.in));
			while(true) {
				System.out.print("請(qǐng)輸入待檢測(cè)的句子(01串) : ");
				inputStr = br.readLine();
				for(int i = 0; i < inputStr.length(); i++) {
					if(inputStr.charAt(i) == input_SYM[0]) {
						next = 1;
					} else {
						next = 2;
					}
					status = matrix_DFA[status.charAt(0) - '0'][next];
					if(i == inputStr.length() - 1) {
						if(status.equals(end_Status)) {
							System.out.println("所輸入句子被識(shí)別!!!");
						} else {
							System.out.println("所輸入句子不能被識(shí)別!!!");
						}
					}
					if(status.equals("@")) {
						System.out.println("所輸入句子不能被識(shí)別!!!");
					}
				}
			}
		} catch(Exception e) {}
	}
	public static void main(String args[]) {
		ConfirmNFA confirm = new ConfirmNFA();

		confirm.getInitData();
		confirm.confirm();
		confirm.display(2);
		confirm.miniDFA();
		confirm.display(2);
		confirm.check();

	}
}

/*
 * 該類的對(duì)象作為根據(jù)NFA構(gòu)造的子集族C的元素
 */
class ClosureStatus {
	private String STATUS;							/* 存放求完閉包之后的狀態(tài)集,其中每一個(gè)字符表示一個(gè)狀態(tài) */
	private boolean TARGET;						/* 標(biāo)記(課本P59算法中提到的標(biāo)記,true為被標(biāo)記狀態(tài),初始值為未標(biāo)記 )*/
	private String ST;									/* 存放用字符代替狀態(tài)集之后的狀態(tài)標(biāo)記 */

	public ClosureStatus() {STATUS = "";	TARGET = false;}
	public String getSTATUS() {return STATUS;}
	public void setSTATUS(String status) {STATUS = status;}
	public boolean isTARGET() {return TARGET;}
	public void setTARGET(boolean target) {TARGET = target;}
	public String getST() {return ST;}
	public void setST(String st) {ST = st;}
}

?? 快捷鍵說(shuō)明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號(hào) Ctrl + =
減小字號(hào) Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
免费成人在线播放| 久久久亚洲精品一区二区三区 | 91精品综合久久久久久| voyeur盗摄精品| 国产成人免费av在线| 国产精品亚洲一区二区三区妖精 | 国产亚洲一区二区在线观看| 91精品中文字幕一区二区三区| 制服丝袜日韩国产| 欧美一区二区三区不卡| 日韩欧美国产小视频| 日韩欧美国产午夜精品| 欧美人与性动xxxx| 91福利社在线观看| 欧美男女性生活在线直播观看| 成人av动漫在线| 高清beeg欧美| 91在线免费播放| 欧美视频一区二区在线观看| 日韩一区二区三区三四区视频在线观看 | 亚洲天堂a在线| 亚洲激情中文1区| 亚洲第一久久影院| 蜜臀av国产精品久久久久| 久久精品免费观看| 成人一区二区视频| 欧美日韩日日夜夜| 欧美精品一区二区三区在线| 亚洲综合色成人| 精品在线观看视频| eeuss国产一区二区三区| 色成年激情久久综合| 日韩欧美激情四射| 亚洲美女视频在线观看| 久热成人在线视频| 91在线精品秘密一区二区| 欧美理论电影在线| 亚洲欧洲三级电影| 美女看a上一区| av高清不卡在线| 日韩一区二区在线播放| 亚洲男女一区二区三区| 日本亚洲一区二区| 不卡的av在线| 精品日韩在线一区| 夜夜嗨av一区二区三区四季av | 久久天天做天天爱综合色| 一区二区三区欧美| 国产精品 日产精品 欧美精品| 91免费小视频| 国产三级三级三级精品8ⅰ区| 天天综合网 天天综合色| 成人av网站免费| 久久久三级国产网站| 亚洲成人先锋电影| 在线观看av不卡| 国产精品国产三级国产普通话99| 麻豆精品久久精品色综合| 欧美综合视频在线观看| 亚洲欧美日韩系列| av亚洲精华国产精华| 久久先锋资源网| 精品影视av免费| 欧美一卡二卡三卡| 亚洲伊人伊色伊影伊综合网| 99久久免费精品| 日本一区二区成人| 国产一区二区三区香蕉| 精品国产乱码久久久久久闺蜜| 亚洲一区二区三区四区在线观看| 97国产精品videossex| 中文av字幕一区| 成人中文字幕电影| 国产精品久久久久精k8 | 亚洲一区二区三区四区不卡| 99re这里只有精品首页| 国产精品卡一卡二卡三| av在线综合网| 一区二区三区毛片| 精品视频123区在线观看| 午夜亚洲国产au精品一区二区| 欧美三级在线看| 日韩中文字幕av电影| 日韩一区二区高清| 国产一区二区在线电影| 亚洲国产精品二十页| youjizz国产精品| 一区二区在线看| 欧美美女喷水视频| 久久av资源网| 国产精品久久久一本精品| 成人午夜激情视频| 亚洲精品第一国产综合野| 欧美日韩精品三区| 九九**精品视频免费播放| 26uuu国产电影一区二区| 成人综合激情网| 五月婷婷综合在线| 精品国产一区二区三区四区四 | 麻豆国产一区二区| 2023国产精华国产精品| 成人综合婷婷国产精品久久| 亚洲激情图片qvod| 精品少妇一区二区三区在线视频 | 91久久精品一区二区三区| 丝袜美腿亚洲一区| 国产蜜臀97一区二区三区| 92精品国产成人观看免费| 石原莉奈在线亚洲二区| 国产丝袜美腿一区二区三区| 91精品福利在线| 久久国产精品第一页| 中文字幕第一区| 欧美高清hd18日本| 成人av电影免费在线播放| 日韩高清中文字幕一区| 国产精品久久久久桃色tv| 69久久99精品久久久久婷婷| 成人av动漫网站| 秋霞av亚洲一区二区三| 亚洲欧洲日韩综合一区二区| 欧美系列亚洲系列| 国产精品白丝av| 日韩av中文在线观看| 精品国产一区二区在线观看| 欧美在线你懂得| 高清视频一区二区| 日韩成人免费看| 亚洲欧美电影院| 中文字幕乱码日本亚洲一区二区| 欧美精品在线观看一区二区| eeuss鲁一区二区三区| 激情综合一区二区三区| 香蕉成人啪国产精品视频综合网| 中文字幕第一页久久| 精品久久久久久久久久久院品网| 色呦呦国产精品| 成人免费av在线| 老司机精品视频导航| 亚洲欧美一区二区久久| 日本一区二区三区在线观看| 精品国产一二三区| 日韩一级成人av| 精品污污网站免费看| 色狠狠一区二区| 一本一道综合狠狠老| av激情亚洲男人天堂| 粉嫩一区二区三区在线看| 国产九色精品成人porny| 免费观看日韩av| 日本欧美韩国一区三区| 婷婷综合另类小说色区| 亚洲午夜私人影院| 樱桃国产成人精品视频| 中文字幕在线播放不卡一区| 国产女人18毛片水真多成人如厕 | 久久久噜噜噜久噜久久综合| 欧美一区二区在线播放| 欧美一区二区三区视频免费| 在线免费观看日本一区| 欧美午夜理伦三级在线观看| 91视频免费播放| 国内外成人在线| 国产九色精品成人porny| 国产一区二区三区蝌蚪| 国产91丝袜在线观看| 成人国产免费视频| 99国产精品久久久久| 成人毛片在线观看| 色婷婷综合在线| 欧美丰满美乳xxx高潮www| 欧美一二三在线| www国产成人| 欧美国产日韩一二三区| 中文字幕在线不卡视频| 亚洲自拍偷拍av| 亚洲国产cao| 日本欧美一区二区| 国产在线精品一区二区不卡了| 国产成人精品网址| 色婷婷综合视频在线观看| 91在线视频官网| 欧美丰满高潮xxxx喷水动漫| 日韩美女一区二区三区| 中文字幕在线观看一区二区| 亚洲一区二区三区视频在线播放 | 欧美三级在线播放| 精品国产露脸精彩对白| 国产精品美女www爽爽爽| 亚洲高清不卡在线| 国产成人在线观看| 91福利国产精品| 久久久久国产精品免费免费搜索| 国产精品欧美一区二区三区| 亚欧色一区w666天堂| 国产一区二区免费视频| 欧美区在线观看| 18欧美乱大交hd1984| 精品无码三级在线观看视频| 91黄色激情网站|