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

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

?? scpascal.cpp

?? pascal編譯器
?? CPP
?? 第 1 頁 / 共 5 頁
字號:

firstTable[expression][0]=id;//expression
firstTable[expression][1]=num;
firstTable[expression][2]=lpare;
firstTable[expression][3]=rw_not;
firstTable[expression][4]=rw_true;
firstTable[expression][5]=rw_false;
firstTable[expression][6]=op_add;
firstTable[expression][7]=op_sub;

firstTable[procedure_statement][0]=id;//procedure_statement

firstTable[expression_list][0]=id;//expression_list
firstTable[expression_list][1]=num;
firstTable[expression_list][2]=lpare;
firstTable[expression_list][3]=rw_not;
firstTable[expression_list][4]=rw_true;
firstTable[expression_list][5]=rw_false;
firstTable[expression_list][6]=op_add;
firstTable[expression_list][7]=op_sub;

firstTable[simple_expression][0]=id;//simple_expression
firstTable[simple_expression][1]=num;
firstTable[simple_expression][2]=lpare;
firstTable[simple_expression][3]=rw_not;
firstTable[simple_expression][4]=rw_true;
firstTable[simple_expression][5]=rw_false;
firstTable[simple_expression][6]=op_add;
firstTable[simple_expression][7]=op_sub;

firstTable[term][0]=id;//term
firstTable[term][1]=num;
firstTable[term][2]=lpare;
firstTable[term][3]=rw_not;
firstTable[term][4]=rw_true;
firstTable[term][5]=rw_false;

firstTable[sign][0]=op_add;//sign
firstTable[sign][1]=op_sub;

firstTable[factor][0]=id;//factor
firstTable[factor][1]=num;
firstTable[factor][2]=lpare;
firstTable[factor][3]=rw_not;
firstTable[factor][4]=rw_true;
firstTable[factor][5]=rw_false;

firstTable[start][0]=rw_program;


}
struct transnode{
	int formula;//公式號
	int dot;	//點位置
	int forward; //向前搜索符號串
	transnode * next;//指向本結構的指針
};
	
//#define struct transnode* transnodePtr



static int Firstback[30];//Firstback[0]是指返回的值的個數初始化為0,后面的是返回的First值初始化為-1。


void First(struct transnode *ptr)        //求任意字符串First集合
{
	int PN;
	int flag=0;

	if (productions[ptr->formula].length < (ptr->dot)) 
		return;

	if (productions[ptr->formula].length == (ptr->dot)){
		Firstback[1+Firstback[0]]=ptr->forward;
		Firstback[0]=Firstback[0]+1;
		return;
	}

	PN = productions[ptr->formula].product[ptr->dot+1];//PN是點后的字符代碼。

	if (PN == empty ) {//PN點后是空
		return;
	}
	

	if (!IsNT(PN)) {	//如果PN是終結符
		Firstback[1+Firstback[0]]=PN;//返回的是該終結符
		Firstback[0]=Firstback[0]+1;
		return;
	}

	if (IsNT(PN)){	//如果PN是非終結符
		for(int i = 0;firstTable[PN][i] != -1;i++){//檢查First表是否該非終結符的First中可以為空
			if (firstTable[PN][i]==empty){//若有空置標志位
				flag=1;
			}
		}

		if (flag==0){//先前檢查沒有空
			int j;
			for(j = 0;firstTable[PN][j] != -1;j++){
				Firstback[j+1+Firstback[0]] = firstTable[PN][j];
			}
			Firstback[0]=Firstback[0]+j;
		}

		if (flag==1){//先前檢查有空
			 struct transnode * tempptr = new struct transnode;
			 //printf("%d ",tempptr);
			 tempptr->formula = ptr->formula;
			 tempptr->forward = ptr->forward;
			 tempptr->dot = ptr->dot+1;
			 First(tempptr);//先遞歸求得為空以后的First
			 int j;
			 for(j = 0;firstTable[PN][j] != -1;j++){
				 if (firstTable[PN][j] != empty){
					 Firstback[j+1+Firstback[0]] = firstTable[PN][j];
				 }
			 }
			 Firstback[0]=Firstback[0]+j-1;
		}
	}
}

typedef struct transnode* transnodePtr;

int PinPtr(transnodePtr p,transnodePtr ptr){			//查看節點p是否在ptr指示的鏈表中存在
	while(ptr != NULL){
		if ((p->formula == ptr->formula)&&
			(p->dot == ptr->dot)&&(p->forward == ptr->forward)){
			return 1;
		}else{
			ptr = ptr->next;
		}
	}
	return 0;
}
void Insert(struct transnode *ptr,struct transnode * newnode){  //在ptr指示的鏈表中插入一個新的結點
	struct transnode *fnode ;
	fnode = ptr;
	if (!PinPtr(newnode,ptr)){
		while (fnode->next != 0) {//一直搜索至最后的節點
			fnode=fnode->next;
		}

		fnode->next=newnode;
		newnode->next=0;
	}
}
int lengthof(struct transnode* p){		//計算結點數目
	int x = 0;
	while(p != NULL){
		x++;
		p = p->next;
	}
	return x;
}

struct transnode * closure(struct transnode *ptr){			//求ptr所指生成式的閉包
	int PN;
	struct transnode *aptr;
	aptr=ptr;
	while (aptr != 0){
		PN = productions[aptr->formula].product[aptr->dot+1];//PN是點后的字符代碼。
		
		{//該程序塊執行對First返回值初始化的任務
			int i;
			Firstback[0]=0;
			for(i = 1;i < 30;i++)
			Firstback[i] = -1;
		}

		//if (productions[ptr->formula].length <= (ptr->dot)); //若點在最后,PN沒有,不作動作

		//if ((PN < 8)&&(PN>3)) ;	//如果PN是終結符,不作動作

		if (IsNT(PN)){
			struct transnode * tempptr = new struct transnode;
			//printf("%d ",tempptr);
			tempptr->formula = aptr->formula;
			tempptr->forward = aptr->forward;
			tempptr->dot = aptr->dot+1;
			First(tempptr);
			
			int i,j;
			for(i = 0;i < LENOFPRODUCTIONS; i++){
				if (productions[i].product[0]==PN)
					for(j = 0;j < Firstback[0];j++){
						struct transnode * newnode = new struct transnode;
						//printf("%d ",newnode);
						newnode->formula = i;//新建的節點公式號是從productions[i].product[1]搜索來
						newnode->dot = 0;//新建的節點點位置在0處
						newnode->forward = Firstback[j+1];//新建的向前搜索符號串是算得得First
						Insert(ptr,newnode);//在ptr指向的鏈表中插入新的一項newnode
					}
			}
		}
		int cc = lengthof(ptr);
		aptr=aptr->next;
	}
	return ptr;
}
//以上是closure()部分的定義,下面開始初始化分析表
#define	MAX	1000	
//狀態棧的定義
int stateStack[MAX];
int point = 0; 
int push(int x){					//進棧函數
	if (point == MAX){
		return 0;
	}else{
		stateStack[point] = x;
		point++;
		return 1;
	}
}
int pop(int x){						//出棧函數
	point = point-x;
	if (point<0){
		point = point+x;
		return 0;
	}else{
		return 1;
	}
}
int top(int x){					//找棧頂
	int i = point-x;
	if (i<0){
		printf("Not so many element in the stack");
		return -1;
	}else{
		return i;
	}
}
void printStack(){				//打印棧
	int i;
	for (i=0;i<point;i++){
		printf("%d",stateStack[i]);
	}
	printf("\n");
}

void printTop(int x){		//打印棧頂
	int i;
	for (i = top(x);i<point;i++){
		printf("%d",stateStack[i]);
	}
	printf("\n");
}

//actionTable和gotoTable分析表的結構定義
#define shift	0
#define reduce	1
#define acc	2
//#define	error	3
#define ok		4
#define MAXSTATES 1000

struct reduceInfo{
	int	formula;
	int	length;
	int leftsym;
};						//歸約信息的結構
union actioninfo{
	int state;
	struct reduceInfo ri;
	void (*p)();
};						//action表的信息
struct actionItem{
	int typ;
	union actioninfo ai; 
};						//action表結點
struct actionItem actionTable[MAXSTATES][NUMOFSYMBOLS];

int	numofstates = 0;

union gotoinfo{
	int state;
	void (*p)();
};					//goto表的信息
struct gotoItem{
	int typ;
	union gotoinfo gi;
};					//goto表的結點
struct gotoItem gotoTable[MAXSTATES][NUMOFSYMBOLS];


struct LR1node{
	int length;
	transnodePtr tp;
};					//LR1項目狀態集的頭結點.

struct LR1node LR1[MAX];
int numofLR1 = 0;

//輸出為增加項目集規范族和對goTable的設置


int compare(transnodePtr p1,transnodePtr p2){		//判斷p1,p2所指鏈表是否完全相同
	transnodePtr p;
	p = p1;
	while(p != NULL){
		if (!(PinPtr(p,p2))){
			return 0;
		}
		p = p->next;
	}
	p = p2;
	while(p != NULL){
		if (!(PinPtr(p,p1))){
			return 0;
		}
		p = p->next;
	}
	return 1;
}
int findinLR1(transnodePtr ptr,int b){				//找新生LR1項目規范族是否已經存在
	int i;
	for (i = 0; i<numofLR1; i++){
		if (LR1[i].length == b){
			if (i == 335){
				printf("");
			}
			if (compare(ptr,LR1[i].tp)){
				return i;
			}
		}
	}
	return numofLR1;
}

void gofrom(int I){					//從LR1狀態分析中狀態遷移函數
	int flag[MAX];
	int i,ax,bx,cx;
	transnodePtr p,newPtr;
	transnodePtr ptr = NULL;

	
	if (I == 11){
		printf("");
	}
	for (i=0; i<MAX; i++){
		flag[i] = 0;
	}
	while(1){
		i = 0;
		p = LR1[I].tp;
		while ((flag[i] != 0) && (p->next != NULL)){
			p = p->next;
			i++;
		}
		
		if (flag[i] == 0){
			flag[i] = 1;
			//判斷是否可做closure
			if (p->dot < productions[p->formula].length){
				//newPtr = (transnodePtr)malloc(sizeof(struct transnode));
				newPtr = new struct transnode;
				//printf("%d ",newPtr);
				newPtr->formula = p->formula;
				newPtr->dot = p->dot+1;
				newPtr->forward = p->forward;
				newPtr->next = NULL;
				ptr = newPtr;
				ax = productions[p->formula].product[(p->dot)+1];
				while (p->next != NULL) {
					p = p->next;
					++i;
					if (flag[i] == 0){
						if (p->dot<productions[p->formula].length){
							if (ax == productions[p->formula].product[(p->dot)+1]){
								//newPtr = (transnodePtr)malloc(sizeof(struct transnode));
								newPtr = new struct transnode;
								//printf("%d ",newPtr);
								newPtr->formula = p->formula;
								newPtr->dot = p->dot+1;
								newPtr->forward = p->forward;
								newPtr->next = ptr;
								ptr = newPtr;
								flag[i] = 1;
							}
						}
					}
				}
				ptr = closure(ptr);
				bx = lengthof(ptr);
				cx = findinLR1(ptr,bx);
				if (cx == numofLR1){
					if (numofLR1 == 405){
						printf("");
					}
					//printf("%d come from %d\n",numofLR1,I);
					if (numofLR1 == 11){
						printf("from %d",I);
					}
					numofLR1++;
					LR1[cx].length = bx;
					LR1[cx].tp = ptr;
				}
				//goTable[I,a] = c;
				if (IsNT(ax)){
					gotoTable[I][ax].typ = ok;
					gotoTable[I][ax].gi.state = cx;
				}else{
					actionTable[I][ax].typ = shift;
					actionTable[I][ax].ai.state = cx;
				}
			}
			else{
				
				if ((p->formula == 0) && (p->forward == DOLLAR)){
					actionTable[I][DOLLAR].typ = acc;
				}else{
					actionTable[I][p->forward].typ = reduce;
					actionTable[I][p->forward].ai.ri.formula = p->formula;
					actionTable[I][p->forward].ai.ri.length = productions[p->formula].length;
					actionTable[I][p->forward].ai.ri.leftsym = productions[p->formula].product[0];
				}
				continue;
			}
		}else{
			break;
		}
	}
}

void InitLR1(){				//初始化LR1項目規范集
	int i;
	for (i=0;i<MAX;i++){
		LR1[i].length = 0;
		LR1[i].tp = NULL;
	}
	
	transnodePtr ptr;

	ptr = new struct transnode;

	ptr->formula = 0;
	ptr->dot = 0;
	ptr->forward = DOLLAR;
	ptr->next = NULL;
	ptr = closure(ptr);
	LR1[0].length = lengthof(ptr);
	LR1[0].tp = ptr;
	numofLR1 = 1;

	i = 0;
	while(i<numofLR1){
		

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
欧美日韩一区不卡| 亚洲视频综合在线| 欧美一区二区免费观在线| 欧美午夜不卡在线观看免费| 97久久久精品综合88久久| 99久久国产综合精品色伊| 色噜噜狠狠色综合中国| 欧美日韩国产在线观看| 婷婷久久综合九色综合伊人色| 人禽交欧美网站| 看电视剧不卡顿的网站| 精品久久五月天| 精品国精品国产尤物美女| 国产色综合一区| 亚洲激情六月丁香| 蜜臀精品久久久久久蜜臀| 国产精品自产自拍| 在线免费一区三区| 久久久久久免费毛片精品| 亚洲美女偷拍久久| 国产一区在线观看视频| 欧日韩精品视频| 欧美一区二区在线看| 一区二区在线观看免费| 粗大黑人巨茎大战欧美成人| xf在线a精品一区二区视频网站| 日韩综合小视频| 欧美亚洲免费在线一区| 香蕉久久夜色精品国产使用方法| 色综合 综合色| 亚洲午夜一区二区| 51久久夜色精品国产麻豆| 天天爽夜夜爽夜夜爽精品视频| 色婷婷综合五月| 日韩精品成人一区二区三区| 欧美成人aa大片| 国产原创一区二区三区| 中文在线免费一区三区高中清不卡| 国产精品18久久久久久久久| 国产亚洲欧美一级| gogogo免费视频观看亚洲一| 亚洲精品日韩一| 6080日韩午夜伦伦午夜伦| 秋霞午夜av一区二区三区| 久久嫩草精品久久久精品一| 成人免费毛片aaaaa**| 亚洲一区在线观看视频| 久久综合中文字幕| 精品久久久久久无| 99精品视频一区二区| 五月婷婷欧美视频| 国产人成亚洲第一网站在线播放 | 欧美一二三四在线| 麻豆精品一二三| 亚洲精品视频在线看| 欧美电影免费观看高清完整版在线| 国产99久久久国产精品潘金| 日韩精品电影在线观看| 一区二区久久久| 国产精品色婷婷久久58| 欧美喷水一区二区| 色久优优欧美色久优优| 国产一区二区成人久久免费影院| 夜夜嗨av一区二区三区四季av| 中文字幕精品一区二区精品绿巨人| 91精品国产入口| 91精品一区二区三区在线观看| 99久久精品国产网站| 成人一级视频在线观看| 国产成人av电影| 成人久久久精品乱码一区二区三区 | 亚洲午夜在线电影| 亚洲美女免费视频| 一色屋精品亚洲香蕉网站| 欧美激情中文字幕一区二区| 精品电影一区二区三区| 日韩精品专区在线影院观看| 欧美精品日日鲁夜夜添| 欧美一级一区二区| 欧美va亚洲va在线观看蝴蝶网| 欧美一区二区精品| 精品国产精品网麻豆系列| 久久久精品中文字幕麻豆发布| 精品av综合导航| 久久精品一区二区| 国产精品美女久久久久高潮| 国产精品国产三级国产普通话99| 国产精品区一区二区三| 一区二区激情视频| 免费看欧美美女黄的网站| 蜜臀久久99精品久久久画质超高清| 日韩影院在线观看| 成人99免费视频| 欧美在线不卡视频| 欧美成人精品二区三区99精品| 久久婷婷色综合| 亚洲国产美女搞黄色| 国产乱人伦偷精品视频免下载| 成人久久久精品乱码一区二区三区| 91丨porny丨中文| 精品少妇一区二区三区在线播放| 综合精品久久久| 久草这里只有精品视频| 91热门视频在线观看| xvideos.蜜桃一区二区| 婷婷激情综合网| 色一情一伦一子一伦一区| 欧美xxxxx裸体时装秀| 亚洲综合激情小说| 99久久99久久精品免费观看| 久久综合九色综合97婷婷女人| 亚洲午夜久久久久久久久电影院 | 日韩成人免费看| 在线视频你懂得一区二区三区| 国产午夜亚洲精品理论片色戒| 天天影视涩香欲综合网| 91.成人天堂一区| 中文字幕在线一区二区三区| 国产精品系列在线播放| 久久蜜桃av一区二区天堂| 麻豆精品一区二区综合av| 日韩一级免费观看| 久久99精品久久久久婷婷| 日韩手机在线导航| 国产乱子伦一区二区三区国色天香| 日韩午夜激情av| 国产精品一线二线三线精华| 国产午夜精品久久久久久久| 国产乱色国产精品免费视频| 国产精品你懂的在线| aaa国产一区| 日韩精品视频网| 国产欧美一区二区精品性色 | 首页国产欧美日韩丝袜| 精品88久久久久88久久久| 风间由美性色一区二区三区| 亚洲一区二区3| 久久久久久久久免费| 欧日韩精品视频| 国产白丝网站精品污在线入口| 亚洲女爱视频在线| 日韩午夜三级在线| 欧美午夜精品电影| 成人一区二区视频| 午夜成人免费视频| 国产精品视频一区二区三区不卡| 欧美最新大片在线看| 国产成人av一区二区三区在线 | av网站免费线看精品| 日韩精品欧美精品| 亚洲视频你懂的| 久久久久久久电影| 欧美一区二区三区免费在线看| 成人aa视频在线观看| 韩国成人精品a∨在线观看| 三级一区在线视频先锋| 亚洲一区二区三区视频在线播放 | 久久久一区二区| 日韩欧美一区二区不卡| 欧美男同性恋视频网站| 色婷婷av一区二区三区之一色屋| 高清不卡一区二区| 丁香六月久久综合狠狠色| 色先锋aa成人| 欧美亚洲尤物久久| 欧美午夜精品一区二区三区 | 夜夜精品浪潮av一区二区三区| 国产精品久久福利| 中文字幕日本不卡| 亚洲线精品一区二区三区| 亚洲第一主播视频| 亚洲电影在线播放| 日韩成人av影视| 精品一区二区精品| 国产精品123区| www.亚洲人| 欧美在线观看你懂的| 欧美日韩国产影片| 久久免费精品国产久精品久久久久| 久久久三级国产网站| 国产精品免费观看视频| 亚洲一区在线观看免费| 天天色综合成人网| 国产超碰在线一区| 欧美婷婷六月丁香综合色| 欧美一级理论片| 国产人久久人人人人爽| 尤物在线观看一区| 国产成人午夜高潮毛片| 欧美日韩久久不卡| 国产日韩欧美精品一区| 国产精品久久久爽爽爽麻豆色哟哟 | 一区二区三区四区蜜桃 | 欧美一卡2卡三卡4卡5免费| 欧美激情在线一区二区| 日韩1区2区日韩1区2区| 欧美色图免费看| 欧美性猛交一区二区三区精品| 色婷婷av一区二区三区gif| 欧美国产一区二区|