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

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

?? slr.cpp

?? 實驗SLR(1)分析表的構造,和大家分享一下.
?? CPP
字號:
#include "SLR.h"

#include <stdio.h>
#include <string.h>
#include <stdlib.h>

#include <conio.h>


SLR::SLR() : Grams()
{
	slrchain=0;
}


int SLR::linksp(struct Stat *st, struct Sp *sp){
	struct Sp *psp=st->sp;
	struct Sp *psp_pre=psp;
	int i=1;

	while(psp){
		if(sp->gid == psp->gid){
			if(sp->dot == psp->dot){		//此狀態已存在
				return 0;
			}else if(sp->dot < psp->dot){
				break;
			}
		}else if(sp->gid < psp->gid){
			break;
		}
		psp_pre=psp;
		psp=psp->next;
		i++;
	}

	if(psp==psp_pre){	//需修改首Sp
		sp->next=st->sp;
		st->sp=sp;
	}else{
		sp->next=psp;
		psp_pre->next=sp;
	}

	if(unendid(getright(sp->gid)[sp->dot])!=-1){
		i*=-1;
	}

	return i;
}


int SLR::closegrm(struct Stat *st){
	struct Sp *sp=st->sp;
	char c;
	int s=0, k=0;

	while(sp){
	//	if(!k){
			c=getright(sp->gid)[sp->dot];		//取出期待輸入符
	//	}
		if(k||(unendid(c)!=-1)){		//為非終結符,需閉包
			k=0;
			struct Gram *pc=gchain;
			int i=0;
			while(pc){
				if(getleft(i)==c){
					struct Sp *newsp=(struct Sp*)malloc(sizeof(struct Sp));
					newsp->gid=i;
					newsp->dot=0;
					newsp->next=0;

					int j=linksp(st,newsp);
					if(!j){
						free(newsp);
					}else if((j<0)&&(j*-1-1<=s)){	//連接后新狀態在前,需回到新狀態繼續檢測
						sp=newsp;
						k=1;
						s=j*-1-1;
						break;
					}
				}
				pc=pc->next;
				i++;
			}
		}
		if(!k){
			sp=sp->next;
			s++;
		}
	}

	return s;
}


struct Stat* SLR::crestat(char c){
	struct Stat *st=(struct Stat*)malloc(sizeof(struct Stat));
	st->in=c;
	st->next=0;
	st->sp=0;
	st->slract=(int*)malloc(sizeof(int)*endc);
	st->slrgoto=(int*)malloc(sizeof(int)*unendc);
	for(int i=0; i<endc; i++){
		st->slract[i]=0;
	}
	for(i=0; i<unendc; i++){
		st->slrgoto[i]=0;
	}

	return st;
}


struct Stat* SLR::tostat(struct Stat* st){
	struct Sp *sp=st->sp;
	struct Stat *stmp=0;
	char c;

	while(sp){
		if(c=getright(sp->gid)[sp->dot]){		//未能歸約
			
			struct Stat *smp=stmp;

			struct Sp *stp=(struct Sp*)malloc(sizeof(struct Sp));
			stp->dot=sp->dot+1;
			stp->gid=sp->gid;
			stp->next=0;

			while(smp){
				if(smp->in==c){	//找到已存在臨時狀態匹配
					struct Sp *ttp=smp->sp;
					while(ttp->next){
						ttp=ttp->next;
					}
					ttp->next=stp;
					c=0;
					break;
				}
				if(smp->next){
					smp=smp->next;
				}else{
					break;
				}
			}
			//找不到匹配臨時狀態,創建
			if(c){
				if(stmp){
					smp->next=crestat(c);
					smp=smp->next;
					smp->sp=stp;
				}else{
					stmp=crestat(c);
					stmp->sp=stp;
				}
			}
		}else{		//歸約
			c=getleft(sp->gid);
			char* pf=getfollow(c);
			
			int u=0;
			for(;pf[u];u++){
				if(c!=*unends||(st->sp->dot!=1)){
					st->slract[endid(pf[u])]=(sp->gid+1)*-1;
				}
			}
		}
		sp=sp->next;
	}

	return stmp;
}


int SLR::chestat(struct Stat* st){
	struct Stat *tst=slrchain;

	int i=0, s=0;

	while(tst){
		if(tst->in==st->in){
			struct Sp *stp=st->sp;
			struct Sp *tstp=tst->sp;
			while(tstp){
				if(!stp){
					s=1;
					break;
				}
				if((stp->gid!=tstp->gid)||(stp->dot!=tstp->dot)){
					s=1;
					break;
				}
				tstp=tstp->next;
				stp=stp->next;
			}
			if(s){
				s=0;
			}else{
				return i;
			}
		}
		tst=tst->next;
		i++;
	}

	return i*-1;
}


int SLR::creatslr(){
	slrchain=crestat(0);
	struct Stat *st=slrchain;
	st->sp=(struct Sp*)malloc(sizeof(struct Sp));

	st->sp->gid=0;
	st->sp->dot=0;
	st->sp->next=0;

	closegrm(st);		//閉包

	do{
		//生成臨時狀態鏈并歸約
		struct Stat *tsp=tostat(st);
		struct Stat *tmp=tsp;
		struct Stat *tmp_pre=tmp;
		int n=0;		//記錄臨時狀態鏈保留個數

		
		while(tmp){
			closegrm(tmp);

			int i=chestat(tmp);		//得到臨時狀態序號和存在狀態

			char c=tmp->in;
			if(i>=0){		//已存在,應刪除
				//寫slr表
				if(endid(c)!=-1){	//為終結符
					st->slract[endid(c)]=i+1;
				}else{
					st->slrgoto[unendid(c)]=i;
				}

				if(tmp_pre==tmp){
					tsp=tmp->next;
					free(tmp);
					tmp=tmp_pre=tsp;
				}else{
					tmp_pre->next=tmp->next;
					free(tmp);
					tmp=tmp_pre->next;
				}
			}else{		//新狀態
				if(endid(c)!=-1){	//為終結符
					st->slract[endid(c)]=i*-1+n+1;
				}else{
					st->slrgoto[unendid(c)]=i*-1+n;
				}

				tmp_pre=tmp;
				tmp=tmp->next;
				
				n++;
			}
		}

		
		//連接臨時狀態鏈到根狀態鏈
		tmp=slrchain;
		while(tmp->next){
			tmp=tmp->next;
		}

		tmp->next=tsp;

		st=st->next;
	}while(st);

	return 0;
}


int SLR::printslr(){
	int n=0;
	//char c;
	struct Stat *st=slrchain;

	printf("狀態 ");
	while(ends[n]){
		printf("%c   ",ends[n]);
		n++;
	}
	n=0;
	while(unends[n]){
		printf("%c  ",unends[n]);
		n++;
	}
	n=0;

	printf("\n");
	while(st){
		printf("%-4d ",n);
		int i=0;
		while(ends[i]){
			if(st->slract[i]>0){
				printf("S%-2d ",st->slract[i]-1);
			}else if(st->slract[i]){
				printf("r%-2d ",st->slract[i]*-1-1);
			}else if((ends[i]=='#')&&(st->sp->gid==0)&&(st->sp->dot==1)){
				printf("acc ");
			}else{
				printf("    ");
			}
			i++;
		}
		i=0;
		
		while(unends[i]){
			if(st->slrgoto[i]){
				printf("%-2d ",st->slrgoto[i]);
			}else{
				printf("   ");
			}
			i++;
		}

		st=st->next;
		n++;
		printf("\n");
	}

	return n;
}


int SLR::anyslr(char *s){
	int statn=0;
	struct Stat *tstp=slrchain;

	while(tstp){
		statn++;
		tstp=tstp->next;
	}

	int *statstack=(int*)malloc(sizeof(int)*statn);
	char *symstack=(char*)malloc(statn+3);
	int statp=0;
	int symp=0;
	int sp=0;

	int n=1;

	//初始化棧
	statstack[statp]=0;
	symstack[symp]=*ends;
	printf("步驟 狀態棧    符號棧    輸入串    \n");
	do{
		//n++;
		printf("%-4d ",n);
		n++;
	
		//打印狀態棧
		for(int k=0; k<=statp; k++){
			printf("%d.",statstack[k]);
		}

		//打印符號棧
		symstack[symp+1]=0;
		printf("     %s",symstack);

		//打印輸入串
		printf("     %s",s+sp);

		//打印Action & Goto
		struct Stat *stpt=slrchain;
		for(k=0; k<statstack[statp]; k++){
			stpt=stpt->next;
		}

		int h,r;
		if((h=endid(s[sp]))!=-1){
			if((r=stpt->slract[h])>0){	//Action
				symstack[++symp]=s[sp++];
				statstack[++statp]=stpt->slract[h]-1;
				printf("     S%d\n",statstack[statp]);
			}else if(r){	//Action & Goto
				r=r*-1-1;
				printf("     r%d",r);

				symp-=strlen(getright(r));

				symstack[++symp]=getleft(r);

				stpt=slrchain;
				for(int k=0; k<statstack[statp-1]; k++){
					stpt=stpt->next;
				}

				statstack[statp]=stpt->slrgoto[unendid(symstack[symp])];
				if(statstack[statp]){
					printf("     %d\n",statstack[statp]);
				}else{
					printf("     Error\n");
					if(statstack){
						free(statstack);
					}
					if(symstack){
						free(symstack);
					}
					return -3;
				}
			}else{
				if((s[sp]=='#')&&(stpt->sp->gid==0)&&(stpt->sp->dot==1)){
					printf("     acc\n");
					if(statstack){
						free(statstack);
					}
					if(symstack){
						free(symstack);
					}
					return 0;
				}else{
					printf("     Error\n");
					if(statstack){
						free(statstack);
					}
					if(symstack){
						free(symstack);
					}
					return -1;
				}
			}
		}else{
			printf("     Error\n");
			if(statstack){
				free(statstack);
			}
			if(symstack){
				free(symstack);
			}
			return -2;
		}
	}while(1);
}

SLR::~SLR(){
	struct Stat *s;
	while(slrchain){
		struct Sp *p=slrchain->sp;
		struct Sp *tp;
		while(p){
			tp=p;
			p=p->next;
			free(tp);
		}

		if(slrchain->slract){
			free(slrchain->slract);
		}
		if(slrchain->slrgoto){
			free(slrchain->slrgoto);
		}

		s=slrchain;
		slrchain=slrchain->next;
		free(s);
	}
}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
欧美性三三影院| 日韩理论片在线| 亚洲视频在线观看一区| 丝袜亚洲另类欧美综合| 不卡av电影在线播放| 欧美精品国产精品| 亚洲欧美区自拍先锋| 国产精品一区二区在线观看网站| 欧美在线视频你懂得| 中文字幕不卡在线观看| 麻豆freexxxx性91精品| 在线精品视频一区二区三四 | 欧美视频你懂的| 国产精品久久久久婷婷二区次| 青娱乐精品在线视频| 色婷婷av一区二区三区软件| 国产精品婷婷午夜在线观看| 精品一区二区三区日韩| 5566中文字幕一区二区电影| 亚洲影视在线播放| 在线视频观看一区| 亚洲靠逼com| 色偷偷久久一区二区三区| 欧美激情一区在线| 成人午夜免费电影| 国产亚洲欧美日韩日本| 黄网站免费久久| 久久久99免费| 国产成人8x视频一区二区| 国产香蕉久久精品综合网| 国产在线播放一区| 久久久久久一级片| 国产一区二区电影| 国产日产欧产精品推荐色| 国内精品在线播放| 国产日韩精品视频一区| 成人av电影免费观看| 中文无字幕一区二区三区| 国产电影一区二区三区| 日本一区二区视频在线| www.欧美亚洲| 有坂深雪av一区二区精品| 欧美中文字幕亚洲一区二区va在线| 亚洲综合色视频| 69久久夜色精品国产69蝌蚪网| 日本不卡视频在线观看| 精品久久久久久久久久久久久久久久久| 久久99精品久久只有精品| 精品国产乱码久久久久久闺蜜| 国产91在线|亚洲| 亚洲视频一区在线| 91麻豆精品国产91久久久| 免费观看在线综合| 国产精品久久久久影院色老大 | 欧美日韩高清影院| 久草在线在线精品观看| 国产亚洲欧美日韩俺去了| 一本一道综合狠狠老| 丝袜国产日韩另类美女| 欧美精品一区视频| 色综合中文字幕国产| 伊人一区二区三区| 欧美成人伊人久久综合网| 成人自拍视频在线| 天天免费综合色| 久久久99精品久久| 欧美中文字幕不卡| 国产成人av电影在线播放| 一区二区三区欧美视频| 精品久久一区二区三区| 91麻豆成人久久精品二区三区| 日韩黄色一级片| 中文字幕在线免费不卡| 69堂成人精品免费视频| 99久精品国产| 极品少妇xxxx偷拍精品少妇| 亚洲欧美色一区| ww久久中文字幕| 欧美日韩一区在线观看| 成人h版在线观看| 久久成人av少妇免费| 亚洲综合偷拍欧美一区色| 国产性色一区二区| 欧美一二三区在线| 91福利在线观看| 成人蜜臀av电影| 精品一区二区三区免费毛片爱| 亚洲香蕉伊在人在线观| 国产精品久久久久久久第一福利 | 成人欧美一区二区三区1314| 欧美一区日本一区韩国一区| 91麻豆精品在线观看| 国产伦精品一区二区三区免费迷 | 日韩欧美一级在线播放| 欧美性猛交一区二区三区精品| 国产成人精品免费在线| 日本不卡一二三| 日日夜夜精品免费视频| 亚洲精品老司机| 亚洲欧美日韩中文字幕一区二区三区 | 久久综合狠狠综合久久激情| 欧美色视频一区| 色婷婷综合中文久久一本| 成人性色生活片| 成人理论电影网| 国产成人亚洲精品青草天美| 激情五月播播久久久精品| 美国av一区二区| 免费黄网站欧美| 麻豆精品国产91久久久久久| 日韩黄色在线观看| 蜜臀av性久久久久蜜臀aⅴ流畅 | 亚洲成人黄色小说| 午夜av一区二区三区| 亚洲一区二区在线免费观看视频| 自拍偷拍亚洲综合| 亚洲欧美欧美一区二区三区| 亚洲男女一区二区三区| 一区二区三区在线观看视频| 一区二区成人在线| 视频一区二区三区在线| 蜜桃91丨九色丨蝌蚪91桃色| 麻豆精品视频在线观看免费| 蜜臀av性久久久久蜜臀aⅴ| 精品在线一区二区三区| 国内精品不卡在线| a在线欧美一区| 欧美视频中文字幕| 91精品国产色综合久久不卡蜜臀 | 粉嫩高潮美女一区二区三区| 国产成人aaaa| 91蝌蚪porny| 欧美日韩免费观看一区二区三区| 欧美肥大bbwbbw高潮| 日韩视频国产视频| 国产校园另类小说区| 一区二区三区四区中文字幕| 日本va欧美va瓶| 成人午夜视频在线观看| 在线欧美日韩国产| 精品美女一区二区三区| 久久久久久久久久久久久女国产乱| 国产精品国产三级国产aⅴ中文| 一区二区三区在线免费| 激情小说亚洲一区| 91久久国产综合久久| 日韩区在线观看| 国产精品伦理在线| 视频一区欧美精品| 成人美女视频在线观看18| 欧美精品日韩综合在线| 中文字幕二三区不卡| 日韩avvvv在线播放| 99re6这里只有精品视频在线观看 99re8在线精品视频免费播放 | 国产永久精品大片wwwapp| 99vv1com这只有精品| 日韩免费一区二区| 亚洲欧洲韩国日本视频| 美国毛片一区二区三区| 在线免费观看视频一区| 国产欧美日韩综合| 亚洲高清久久久| 成av人片一区二区| 精品少妇一区二区三区日产乱码 | 欧美日韩在线综合| 国产免费观看久久| 人妖欧美一区二区| 91黄色免费看| 中文字幕视频一区| 国产麻豆欧美日韩一区| 在线不卡一区二区| 亚洲精品日产精品乱码不卡| 国产**成人网毛片九色| 欧美一区二区三区不卡| 亚洲二区视频在线| 色综合天天综合给合国产| 久久亚洲免费视频| 麻豆精品在线播放| 欧美精品日韩一本| 午夜久久久影院| 日本道免费精品一区二区三区| 国产精品色哟哟| 国产成人精品1024| 久久久久久9999| 国产一区三区三区| 日韩精品一区二区三区视频播放 | 中文字幕不卡在线观看| 国产一区二区三区久久悠悠色av| 欧美美女一区二区三区| 夜夜亚洲天天久久| 色综合激情久久| 一区二区在线观看视频| 91首页免费视频| 亚洲人吸女人奶水| 色先锋资源久久综合| 亚洲在线观看免费| 欧美少妇xxx| 肉色丝袜一区二区| 日韩欧美亚洲一区二区| 精一区二区三区|