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

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

?? parsingtable.java

?? java寫的詞法和語法分析器
?? JAVA
字號:
package cminus;
/**
 * Class-name:ParsingTable
 * 功能:構造文法的分析表,并將其用一定的數據結構保存。
 * @author Administrator
 *
 */
import java.util.*;
import java.io.*;

public class ParsingTable extends FollowSet {
	// 存儲終結符號的鏈表
	public LinkedList listTerminals;
	// 終結符的個數
	public int numOfTerminals;
	// String型的二維數組,用來存儲分析表
	public String [][] parsingTable ;
	// 用來將非終結符號按候選分開存放的鏈表
	public LinkedList listNonTerminalApartly = new LinkedList();
	
	/**
	 * 構造函數
	 * 
	 * @param fileName -文法文件絕對路徑
	 */
	public ParsingTable(String fileName) {
		super(fileName);
	}
	/**
	 * 初始化存儲分析表的二維數組
	 *
	 */
	public void initParsingTable(){
		this.getNumOfTerminals();
		this.constructNonTerminalListApartly();
		this.parsingTable = new String[this.numOfNonTerminals][this.numOfTerminals];
		for(int i = 0;i<this.numOfNonTerminals;i++){
			for(int j= 0 ;j<this.numOfTerminals;j++){
				this.parsingTable[i][j] = "";
			}
		}
	}
	/**
	 * 建立非終結字符按照候選的分類列表
	 *
	 */
	public void constructNonTerminalListApartly(){
		for(int i = 0;i<this.vectorFirstSetApart.size();i++){
			LinkedList list = (LinkedList)this.vectorFirstSetApart.get(i);
			this.listNonTerminalApartly.add(list.get(0));
		}
	}
	/**
	 * 打印分析表
	 *
	 */
	public void printParsingTable(){
		System.out.println("\nThe parsing table of the grammar is:");
		/*// print the column header
		String output = "";
		System.out.print("\t");
		for(int s = 0;s<this.listTerminals.size();s++){
			System.out.print(this.listTerminals.get(s)+"\t");
		}
		System.out.println();
		for(int i = 0;i<this.numOfNonTerminals;i++){
			//print the row header
			System.out.print(this.listNonTerminals.get(i)+"\t");
			for(int j= 0 ;j<this.numOfTerminals;j++){
				System.out.print("("+i+","+j+")"+"\t");
				output+="("+i+","+j+")-->"+this.parsingTable[i][j]+"\n";
			}
			System.out.println();
		}
		System.out.println(output);
		*/
		for(int s = 0;s<this.parsingTable.length;s++){
			for(int i = 0;i<this.parsingTable[s].length;i++){
				if(this.parsingTable[s][i].length()>0){
					String nonterminal = (String)this.listNonTerminals.get(s);
					String terminal = (String)this.listTerminals.get(i);
					System.out.println("ParsingTable["+nonterminal+","+terminal+"]: "+this.parsingTable[s][i]);
				}
			}
		}
	}
	/**
	 * Construct the parsing table and store it 
	 * int a array which size of "numOfNonTerminals * numOfNonTerminals". 
	 * 
	 */
	public void constructParsingTable(){
		for(int i = 0 ;i<this.listGrammar.length;i++){
			//對每個候選構造分析表的元素
			String element = "";
			for(int k = 0;k<this.listGrammar[i].size();k++){
				if(k == 1){
					element+="→";
					element +=(String)this.listGrammar[i].get(k)+" ";
				}
				else{
					element +=(String)this.listGrammar[i].get(k)+" ";
				}
			}
			//對由此候選求出的first集合
			String nonterminal = (String)this.listFirstSetApart[i].get(0);
			int row = this.listNonTerminals.indexOf(nonterminal);
			for(int j= 1;j<this.listFirstSetApart[i].size();j++){
				String terminal  = (String)this.listFirstSetApart[i].get(j);
				//如果此token不是空字
				if(!terminal.equalsIgnoreCase("EMPTY")){
					int col = this.listTerminals.indexOf(terminal);
					if(this.parsingTable[row][col].length()==0){
						this.parsingTable[row][col]= element;
					}
					else{
						// report error.
						if(nonterminal.equals("selection-stmt-1")){
							if((this.parsingTable[row][col].trim()).equals("selection-stmt-1 →EMPTY")){
								this.parsingTable[row][col]= element;
							}
						}
						else{
							System.err.println("The grammar is not LL(1)--分析表單元格不為空.\nProgram will exit...");
							int line = this.listNonTerminals.indexOf(nonterminal)+1;
							System.err.println("Line no--"+line+":\t"+nonterminal);
							System.err.println("old elmement: 	"+this.parsingTable[row][col]);
							System.err.println("new elmement: 	"+element);
							try{
								System.in.read();
								System.exit(0);
							}catch(IOException e){
								e.printStackTrace();
							}
						}
					}
				}
				//如果此token是空字,轉到follow集
				else{
					for(int kk = 0;kk<this.listFollowSet.length;kk++){
						LinkedList list  = (LinkedList)this.listFollowSet[kk];
						String str = (String)list.get(0);
						if(str.equals(nonterminal)){
							for(int k = 1;k<this.listFollowSet[kk].size();k++){
								terminal = (String)this.listFollowSet[kk].get(k);
								int col = this.listTerminals.indexOf(terminal);
								if(this.parsingTable[row][col].length()==0){
									this.parsingTable[row][col]= element;
								}
								else{
									// report error.
									if(nonterminal.equals("selection-stmt-1")){
										if((this.parsingTable[row][col].trim()).equals("selection-stmt-1 →EMPTY")){
											this.parsingTable[row][col]= element;
										}
									}
									else{
										System.err.println("The grammar is not LL(1)--分析表單元格不為空.\nProgram will exit...");
										int line = this.listNonTerminals.indexOf(nonterminal)+1;
										System.err.println("Line no--"+line+":\t"+nonterminal);
										System.err.println("old elmement: 	"+this.parsingTable[row][col]);
										System.err.println("new elmement: 	"+element);
										try{
											System.in.read();
											System.exit(0);
										}catch(IOException e){
											e.printStackTrace();
										}
									}
								}
							}
						}
						
					}
				}
				
			}
		}//end of for
	}

	/**
	 * Get the number of non-terminal symbol of a grammar
	 * 
	 */
	public  void getNumOfTerminals() {
		listTerminals = new LinkedList();
		for (int i = 0; i < this.numOfNonTerminals; i++) {
			for (int j = 1; j < this.listFirstSet[i].size(); j++) {
				String str = (String) this.listFirstSet[i].get(j);
				if (!str.equalsIgnoreCase("empty")) {
					if (!listTerminals.contains(str)) {
						listTerminals.add(str.trim());
					}
				}
			}
		}
		for (int i = 0; i < this.numOfNonTerminals; i++) {
			for (int j = 1; j < this.listFollowSet[i].size(); j++) {
				String str = (String) this.listFollowSet[i].get(j);
				if (!str.equalsIgnoreCase("empty")) {
					if (!listTerminals.contains(str)) {
						listTerminals.add(str.trim());
					}
				}
			}
		}
		this.numOfTerminals = listTerminals.size();
	}

	public static void main(String args[]) {
		ParsingTable table = new ParsingTable("c-minus-2");
	}
}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
蜜桃一区二区三区四区| 91玉足脚交白嫩脚丫在线播放| 激情小说欧美图片| 91福利视频在线| 久久久久亚洲综合| 五月婷婷激情综合网| av一区二区不卡| 欧美白人最猛性xxxxx69交| 亚洲三级久久久| 成人午夜视频网站| 精品国产区一区| 日韩国产精品大片| 91麻豆免费看片| 亚洲国产高清aⅴ视频| 毛片基地黄久久久久久天堂| 91啪九色porn原创视频在线观看| 久久久777精品电影网影网| 日韩福利电影在线观看| 欧洲精品一区二区| 日韩毛片高清在线播放| 成人免费高清视频在线观看| 亚洲精品一区在线观看| 美女视频网站黄色亚洲| 欧美日本一区二区在线观看| 亚洲免费看黄网站| av网站免费线看精品| 国产免费观看久久| 国产成人免费网站| 国产无人区一区二区三区| 国产美女娇喘av呻吟久久| 精品国产一区二区在线观看| 另类中文字幕网| 日韩欧美国产一区在线观看| 日韩国产欧美在线播放| 7777精品伊人久久久大香线蕉超级流畅 | 日本午夜一本久久久综合| 欧美色爱综合网| 性感美女久久精品| 欧美一区二区网站| 久久精品国产秦先生| 精品sm捆绑视频| 国产老肥熟一区二区三区| 国产午夜精品美女毛片视频| 成人在线视频首页| 亚洲视频小说图片| 欧美色爱综合网| 久久国产精品色婷婷| 久久久久97国产精华液好用吗| 国产精品一二三在| 国产精品三级av在线播放| 欧美日韩一区二区三区在线看| 亚洲免费观看高清完整版在线 | 亚洲va欧美va天堂v国产综合| 欧美日韩电影在线| 久久成人免费网| 中文字幕av一区二区三区高| 91浏览器在线视频| 日本亚洲三级在线| 国产校园另类小说区| 91在线观看美女| 日韩精品一二区| 久久午夜免费电影| 99国产精品一区| 青青青爽久久午夜综合久久午夜| 久久久午夜电影| 91免费看视频| 另类调教123区| **网站欧美大片在线观看| 欧美日韩精品免费| 国产精品一线二线三线| 一区二区三区中文在线观看| 欧美一区三区四区| 成人美女在线视频| 午夜欧美大尺度福利影院在线看| 日韩视频免费观看高清完整版 | 国产欧美日韩在线| 欧美亚日韩国产aⅴ精品中极品| 捆绑调教美女网站视频一区| 国产精品福利电影一区二区三区四区| 欧美浪妇xxxx高跟鞋交| 粉嫩av一区二区三区粉嫩| 性欧美大战久久久久久久久| 亚洲国产电影在线观看| 欧美一区二区三区公司| 91原创在线视频| 国产精品亚洲第一| 日韩电影在线一区二区| 国产精品不卡视频| 精品卡一卡二卡三卡四在线| 91久久国产最好的精华液| 国产精品系列在线播放| 日韩精品午夜视频| 亚洲在线视频免费观看| 国产欧美精品在线观看| 色欲综合视频天天天| 欧美日韩一区二区在线视频| 亚洲成国产人片在线观看| 国产精品视频一二| 精品少妇一区二区三区免费观看 | 91麻豆自制传媒国产之光| 国产精品自拍在线| 另类小说一区二区三区| 日韩不卡免费视频| 亚洲h动漫在线| 亚洲三级电影网站| 中文欧美字幕免费| 国产成人三级在线观看| 日韩视频在线观看一区二区| 在线观看一区二区精品视频| 99热99精品| 成人精品亚洲人成在线| 一本大道久久a久久精二百| 国产精品主播直播| 国产精品一区二区免费不卡| 精品一区二区三区免费播放| 日本午夜一本久久久综合| 日韩精品国产欧美| 日本麻豆一区二区三区视频| 日韩国产在线观看| 日本一不卡视频| 久久99热这里只有精品| 精一区二区三区| 国内精品伊人久久久久av一坑 | 国产成人午夜片在线观看高清观看| 美美哒免费高清在线观看视频一区二区 | 91啪在线观看| 色丁香久综合在线久综合在线观看| 色妞www精品视频| 在线观看日韩高清av| 欧美日韩综合在线| 日韩午夜在线观看| 26uuu成人网一区二区三区| 久久久精品免费免费| 国产日韩欧美激情| 中文字幕在线一区二区三区| 中文字幕亚洲成人| 亚洲综合丝袜美腿| 日韩二区三区在线观看| 精品一区二区三区免费观看| 懂色av噜噜一区二区三区av| 91丝袜高跟美女视频| 在线观看亚洲a| 日韩一区二区影院| 国产目拍亚洲精品99久久精品| 国产精品久久久久久亚洲伦| 一区二区三区资源| 麻豆精品一区二区av白丝在线| 国产在线精品国自产拍免费| 94-欧美-setu| 日韩一区二区在线看| 国产精品久久久久精k8| 五月天国产精品| 高清成人免费视频| 欧美日韩情趣电影| 久久久国产一区二区三区四区小说 | 在线不卡a资源高清| 26uuu成人网一区二区三区| 综合分类小说区另类春色亚洲小说欧美| 91啪在线观看| 欧美不卡视频一区| 一区二区三区四区五区视频在线观看 | 久久精品国产成人一区二区三区| 粉嫩蜜臀av国产精品网站| 91福利社在线观看| 久久亚洲精品小早川怜子| 日本美女一区二区| 福利一区二区在线| 欧美一区二区视频在线观看2022| 亚洲视频在线一区观看| 精品一区二区在线免费观看| 在线观看亚洲a| 中文字幕一区免费在线观看| 精品一区二区日韩| 欧美精品电影在线播放| 亚洲日本在线天堂| 成人一区在线看| 精品日韩av一区二区| 亚洲成人精品在线观看| 99久久伊人精品| 久久久精品综合| 国内精品写真在线观看| 91精品久久久久久久久99蜜臂| 亚洲欧洲成人av每日更新| 国产一区二区三区高清播放| 3atv一区二区三区| 亚洲小说春色综合另类电影| 波波电影院一区二区三区| 久久亚洲一区二区三区四区| 日韩高清不卡一区二区| 精品视频免费在线| 伊人开心综合网| 一本大道av一区二区在线播放| 国产精品女主播在线观看| 狠狠色狠狠色综合日日91app| 欧美肥大bbwbbw高潮| 亚洲电影一级片| 欧美猛男gaygay网站| 亚洲第四色夜色| 69堂成人精品免费视频| 日韩成人精品在线观看|