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

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

?? pl0.c

?? pl0編譯器,包括詞法分析,語法語義分析,以及解釋執(zhí)行
?? C
?? 第 1 頁 / 共 2 頁
字號(hào):
#include <stdio.h>
#include <string.h>
#include "pl0.h"

int getch()
{
	if(cc==ll)                          //如果一行緩存取完
	{
		if(feof(fin))
		{
			printf("Program incomplete!");
			return -1;
		}
		cc=0;                           //當(dāng)前行取詞位置初始化
		ll=0;                           //當(dāng)前行取詞總數(shù)初始化
		ch=' ';
		while(ch!=10&&ll<=81)
		{
			ch=fgetc(fin);
			if(feof(fin))
			{
				ch=0;
				break;
			}
			line[ll]=ch;
			printf("%c",ch);
			fprintf(fa1,"%c",ch);
			ll++;
		}
	}
	ch=line[cc];
	cc++;
	return 0;
}
	
int getsym()
{
	while(ch==10||ch==32||ch==9)
	{
		if(getch()==-1)
			return -1;
	}
	if(ch>='a'&&ch<='z')                //字母開頭可能是標(biāo)識(shí)符或關(guān)鍵字
	{
		int k=0;
		do{
			if(k<WMAX)                  //最多讀入WMAX個(gè)字符
				tmp[k]=ch;
			if(getch()==-1)
				return -1;
			k++;
		}while(ch>='a'&&ch<='z'||ch>='0'&&ch<='9');
		tmp[k]=0;
		strcpy(id,tmp);
		for(k=0;k<NKEY;k++)
		{
			if(strcmp(id,word[k])==0)
			{
				sym=wsym[k];
				break;
			}
		}
		if(k>=NKEY)
			sym=ident;
	}
	else if(ch>='0'&&ch<='9')            //開頭為數(shù)字,當(dāng)作常數(shù)
	{
		int k=0;
		num=0;
		sym=number;
		do{
			num=num*10+ch-'0';
			k++;
			if(getch()==-1)
				return -1;
		}while(ch>='0'&&ch<='9');
		if(k>NMAX)
			error(0);
	}
	else                                 //剩下的是單雙字符符號(hào)
	{
		if(ch==':')
		{
			if(getch()==-1)
				return -1;
			if(ch=='=')
			{
				sym=becomes;
				if(getch()==-1)
					return -1;
			}
			else
				sym=nul;
		}
		else if(ch=='>')
		{
			if(getch()==-1)
				return -1;
			if(ch=='=')
			{
				sym=geq;
				if(getch()==-1)
					return -1;
			}
			else
				sym=gtr;
		}
		else if(ch=='<')
		{
			if(getch()==-1)
				return -1;
			if(ch=='=')
			{
				sym=leq;
				if(getch()==-1)
					return -1;
			}
			else
				sym=lss;
		}
		else
		{
			sym=ssym[ch];
			if(sym!=period)              //當(dāng)且僅當(dāng)當(dāng)前符號(hào)是句號(hào)時(shí),
			{                            //不再讀入一個(gè)符號(hào)
				if(getch()==-1)
					return -1;
			}
		}
	}
	return 0;
}

int inset(int e,int *s)
{
	return s[e];
}

int addset(int *sr,int *s1,int *s2,int n)
{
	int i;
	for(i=0;i<n;i++)
		sr[i]=s1[i]||s2[i];
	return 0;
}

int subset(int *sr,int *s1,int *s2,int n)
{
	int i;
	for(i=0;i<n;i++)
		sr[i]=s1[i]&&(!s2[i]);
		return 0;
}

int mulset(int *sr,int *s1,int *s2,int n)
{
	int i;
	for(i=0;i<n;i++)
		sr[i]=s1[i]&&s2[i];
	return 0;
}
	
void init()
{
	int i;
	for(i=0;i<256;i++)
		ssym[i]=nul;
	ssym['=']=eql;
	ssym[',']=comma;
	ssym['.']=period;
	ssym['#']=neq;
	ssym[';']=semicolon;
	ssym['(']=lparen;
	ssym[')']=rparen;
	ssym['+']=plus;
	ssym['-']=minus;
	ssym['*']=times;
	ssym['/']=slash;
	strcpy(word[0],"begin");
	strcpy(word[1],"call");
	strcpy(word[2],"const");
	strcpy(word[3],"do");
	strcpy(word[4],"end");
	strcpy(word[5],"if");
	strcpy(word[6],"odd");
	strcpy(word[7],"procedure");
	strcpy(word[8],"read");
	strcpy(word[9],"then");
	strcpy(word[10],"var");
	strcpy(word[11],"while");
	strcpy(word[12],"write");
	strcpy(mc[0],"lit");
	strcpy(mc[1],"opr");
	strcpy(mc[2],"lod");
	strcpy(mc[3],"sto");
	strcpy(mc[4],"cal");
	strcpy(mc[5],"inte");
	strcpy(mc[6],"jmp");
	strcpy(mc[7],"jpc");
	wsym[0]=beginsym;
	wsym[1]=callsym;
	wsym[2]=constsym;
	wsym[3]=dosym;
	wsym[4]=endsym;
	wsym[5]=ifsym;
	wsym[6]=oddsym;
	wsym[7]=procsym;
	wsym[8]=readsym;
	wsym[9]=thensym;
	wsym[10]=varsym;
	wsym[11]=whilesym;
	wsym[12]=writesym;
	for(i=0;i<SYMNUM;i++)
	{
		dcbsys[i]=0;
		stbsys[i]=0;
		fcbsys[i]=0;
	}
	dcbsys[constsym]=1;
	dcbsys[varsym]=1;
	dcbsys[procsym]=1;
	stbsys[beginsym]=1;
	stbsys[callsym]=1;
	stbsys[ifsym]=1;
	stbsys[whilesym]=1;
	fcbsys[ident]=1;
	fcbsys[number]=1;
	fcbsys[lparen]=1;
}

void error(int n)
{
	char space[81];
	memset(space,32,81);
	space[cc-2]=0;
	printf("%s%c%s\n",space,24,errinfo[n]);  //24為向上箭頭符號(hào),指使出錯(cuò)位置
	fprintf(fa1,"%s%c%s\n",space,24,errinfo[n]);
	err++;
}

int mb(int lev,int tx,int *s)
{
	int ts[SYMNUM];                   //看作布爾集合數(shù)組傳給子程序
	int tx0=tx;
	int dx=3;
	tb[tx].adr=cx;
	if(gen(jmp,0,0)==-1)
		return -1;
	if(lev>LVMAX)
		error(1);
	do                                //聲明部分
	{
		if(sym==constsym)
		{
			if(getsym()==-1)
				return -1;
			constdc(&tx,lev,&dx);
			while(sym==comma)
			{
				if(getsym()==-1)
					return -1;
				constdc(&tx,lev,&dx);
			}
			if(sym!=semicolon)
				error(2);
			else
			{
				if(getsym()==-1)
					return -1;
			}
		}
		if(sym==varsym)
		{
			if(getsym()==-1)
				return -1;
			vardc(&tx,lev,&dx);
			while(sym==comma)
			{
				if(getsym()==-1)
					return -1;
				vardc(&tx,lev,&dx);
			}
			if(sym!=semicolon)
				error(3);
			else
			{
				if(getsym()==-1)
					return -1;
			}
		}
		while(sym==procsym)
		{
			if(getsym()==-1)
				return -1;
			if(sym==ident)
			{
				record(procedure,&tx,lev,&dx);
				if(getsym()==-1)
					return -1;
				if(sym!=semicolon)
					error(4);
				else
				{
					if(getsym()==-1)
						return -1;
				}
			}
			else
				error(5);
			memcpy(ts,s,sizeof(int)*SYMNUM);
			ts[semicolon]=1;
			if(mb(lev+1,tx,ts)==-1)
				return -1;
			if(sym==semicolon)
			{
				if(getsym()==-1)
					return -1;
				memcpy(ts,stbsys,sizeof(int)*SYMNUM);
				ts[procsym]=1;
				ts[ident]=1;
				if(test(ts,s,8)==-1)
					return -1;
			}
			else
				error(6);
		}
		memcpy(ts,stbsys,sizeof(int)*SYMNUM);
		ts[period]=1;
		ts[ident]=1;
		if(test(ts,s,9)==-1)
			return -1;
	}while(inset(sym,dcbsys));
	code[tb[tx0].adr].a=cx;
	tb[tx0].size=dx;
	tb[tx0].adr=cx;

	if(gen(inte,0,dx)==-1)             //分配存儲(chǔ)語句
		return -1;
	memcpy(ts,s,sizeof(int)*SYMNUM);   //語句部分
	ts[semicolon]=1;
	ts[endsym]=1;
	if(stat(&tx,ts,lev)==-1)
		return -1;
	if(gen(opr,0,0)==-1)
		return -1;
	memset(ts,0,sizeof(int)*SYMNUM);
	if(test(s,ts,10)==-1)
		return -1;
	return 0;
}

int test(int *s1,int *s2,int n)
{
	if(!inset(sym,s1))
	{
		error(n);
		while(!inset(sym,s1)&&!inset(sym,s2))
		{
			if(getsym()==-1)
				return -1;
		}
	}
	return 0;
}

int constdc(int *ptx,int lev,int *pdx)
{
	if(sym==ident)
	{
		if(getsym()==-1)
			return -1;
		if(sym==becomes)
			error(11);
		else if(sym==eql)
		{
			if(getsym()==-1)
				return -1;
			if(sym==number)
			{
				record(constant,ptx,lev,pdx);
				if(getsym()==-1)
					return -1;
			}
			else
				error(12);
		}
		else
			error(13);
	}
	else
		error(14);
	return 0;
}

int vardc(int *ptx,int lev,int *pdx)
{
	if(sym==ident)
	{
		record(variable,ptx,lev,pdx);
		if(getsym()==-1)
			return -1;
	}
	else
		error(15);
	return 0;
}

void record(enum obj k,int *ptx,int lv,int *pdx)
{
	(*ptx)++;
	tb[*ptx].kind=k;
	strcpy(tb[*ptx].name,id);
	if(k==constant)
	{
		if(num>AMAX)
		{
			error(7);           //數(shù)越界
			num=0;
		}
		tb[*ptx].val=num;	
	}
	else if(k==variable)
	{
		tb[*ptx].adr=*pdx;
		tb[*ptx].lev=lv;
		(*pdx)++;
	}
	else if(k==procedure)
		tb[*ptx].lev=lv;
}

int gen(enum fct x,int y,int z)
{
	if(cx==1000)
		printf("%s",id);
	if(cx>CXMAX)
	{
		printf("Program too long!\n");
		return -1;
	}
	code[cx].f=x;
	code[cx].l=y;
	code[cx].a=z;
	cx++;
	return 0;
}

int extable(char *idt,int tx)
{
	int j;
	for(j=tx;j>0;j--)
	{
		if(strcmp(tb[j].name,idt)==0)
			return j;
	}
	return 0;
}

int stat(int *ptx,int *s,int lev)
{
	int p;
	int ts[SYMNUM];
	if(sym==ident)
	{
		p=extable(id,*ptx);
		if(p==0)
			error(16);
		else
		{
			if(tb[p].kind!=variable)
			{
				error(17);
				p=0;
			}
			else
			{
				if(getsym()==-1)
					return -1;
				if(sym==becomes)
				{
					if(getsym()==-1)
						return -1;
					memcpy(ts,s,sizeof(int)*SYMNUM);
					if(exp(ptx,ts,lev)==-1)
						return -1;
				}
				else
				{
					error(18);
					p=0;
				}
			}
		}
		if(p!=0)
		{
			if(gen(sto,lev-tb[p].lev,tb[p].adr)==-1)
				return -1;
		}
	}
	else if(sym==callsym)
	{
		if(getsym()==-1)
			return -1;
		if(sym==ident)
		{
			p=extable(id,*ptx);
			if(p==0)
				error(25);
			else
			{
				if(tb[p].kind!=procedure)
				{
					error(26);
					p=0;
				}
				else
				{
					if(getsym()==-1)
						return -1;
				}
			}
		}
		else
		{
			error(27);
			p=0;
		}
		if(p!=0)
		{
			if(gen(cal,lev-tb[p].lev,tb[p].adr)==-1)
				return -1;
		}
	}
	else if(sym==beginsym)
	{
		if(getsym()==-1)
			return -1;
		memcpy(ts,s,sizeof(int)*SYMNUM);
		ts[semicolon]=1;
		ts[endsym]=1;
		if(stat(ptx,ts,lev)==-1)
			return -1;
		while(inset(sym,stbsys)||sym==semicolon)
		{
			if(sym==semicolon)
			{
				if(getsym()==-1)
					return -1;
			}
			else
				error(29);
			if(stat(ptx,ts,lev)==-1)
				return -1;
		}
		if(sym!=endsym)
			error(30);
		else
		{
			if(getsym()==-1)
				return -1;
		}
	}
	else if(sym==ifsym)
	{
		int cx1;
		if(getsym()==-1)
			return -1;
		memcpy(ts,s,sizeof(int)*SYMNUM);
		ts[thensym]=1;
		ts[dosym]=1;
		if(con(ptx,ts,lev)==-1)
			return -1;
		cx1=cx;
		if(gen(jpc,0,0)==-1)
			return -1;
		if(sym!=thensym)
			error(28);
		else
		{

?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號(hào) Ctrl + =
減小字號(hào) Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
亚洲国产视频在线| 国产精品资源在线看| 精品99999| 一本久久a久久精品亚洲| 日韩成人一区二区三区在线观看| 国产亚洲自拍一区| 欧美高清dvd| 99精品久久99久久久久| 九九精品一区二区| 三级一区在线视频先锋| 国产精品国产馆在线真实露脸 | 亚洲一区免费在线观看| 国产欧美视频在线观看| 欧美一区二视频| 欧美日韩精品欧美日韩精品| 成人av综合在线| 国产精品香蕉一区二区三区| 免费亚洲电影在线| 日韩经典中文字幕一区| 亚洲影院免费观看| 国产精品久久久久久久久久久免费看 | 美女视频一区二区| 亚洲一本大道在线| 玉米视频成人免费看| 国产精品亲子乱子伦xxxx裸| 久久嫩草精品久久久精品| 67194成人在线观看| 欧美日韩一区 二区 三区 久久精品| www.久久久久久久久| 国产凹凸在线观看一区二区| 极品美女销魂一区二区三区| 蜜臀精品一区二区三区在线观看 | 日韩欧美一级二级三级久久久 | 国产精品美女久久久久久久久久久| 精品国产91洋老外米糕| 91精品国产综合久久婷婷香蕉| 精品视频在线视频| 欧美日韩一区中文字幕| 欧美群妇大交群的观看方式| 欧美日韩国产三级| 欧美日韩日日夜夜| 在线综合视频播放| 精品久久久久久久久久久久久久久| 日韩欧美中文一区| 精品国产免费人成在线观看| 2023国产精品自拍| 久久综合色播五月| 国产日韩精品一区二区浪潮av| 久久久不卡影院| 亚洲国产电影在线观看| 亚洲欧美一区二区久久 | 日韩激情一区二区| 美脚の诱脚舐め脚责91| 国产一区二区三区精品欧美日韩一区二区三区 | 韩国女主播一区二区三区| 美女在线观看视频一区二区| 久久99久久久欧美国产| 国产成人自拍网| 99久久精品国产导航| 在线观看精品一区| 日韩一级片网站| 国产色综合一区| 亚洲欧美日韩一区二区| 亚洲国产wwwccc36天堂| 精品在线观看免费| 成人精品免费视频| 精品视频一区二区不卡| 欧美tickle裸体挠脚心vk| 欧美国产丝袜视频| 亚洲一卡二卡三卡四卡| 麻豆视频一区二区| 成人激情动漫在线观看| 欧美日韩久久不卡| 久久影院视频免费| 亚洲精品亚洲人成人网在线播放| 午夜精品爽啪视频| 国产成人免费视频一区| 欧美日韩色综合| 欧美激情在线一区二区| 午夜视黄欧洲亚洲| 国产91色综合久久免费分享| 欧美亚洲一区二区在线观看| 精品成人佐山爱一区二区| 亚洲色欲色欲www| 另类欧美日韩国产在线| 色综合天天综合狠狠| 日韩欧美一二区| 亚洲老司机在线| 国产在线看一区| 欧美色图在线观看| 国产精品你懂的在线欣赏| 婷婷综合另类小说色区| www.66久久| 精品91自产拍在线观看一区| 亚洲国产欧美另类丝袜| 国产91精品精华液一区二区三区 | 精品噜噜噜噜久久久久久久久试看| 中文字幕欧美日韩一区| 免费美女久久99| 91国产精品成人| 国产精品美女一区二区| 久久99精品国产| 欧美理论电影在线| 综合激情成人伊人| 高清不卡在线观看av| 日韩欧美一区电影| 亚洲二区在线观看| 99精品视频在线播放观看| 2024国产精品| 免费在线观看成人| 欧美日高清视频| 亚洲欧美另类图片小说| 国产成人在线视频播放| 日韩精品一区二区三区在线 | 日本韩国精品在线| 国产精品欧美极品| 国产精品一二三区| 精品福利av导航| 日韩不卡一区二区| 在线成人av影院| 亚洲国产精品人人做人人爽| 91成人网在线| 亚洲三级在线播放| 91亚洲国产成人精品一区二区三| 国产午夜亚洲精品理论片色戒| 久久成人免费网站| 日韩午夜电影av| 久久精品国内一区二区三区| 91精品国产色综合久久久蜜香臀| 亚洲第一搞黄网站| 欧美日韩大陆一区二区| 日韩精品亚洲一区二区三区免费| 欧美日韩成人激情| 午夜亚洲福利老司机| 欧美色偷偷大香| 日本怡春院一区二区| 日韩欧美美女一区二区三区| 日韩激情在线观看| 精品日韩av一区二区| 国产制服丝袜一区| 国产欧美日韩亚州综合| 本田岬高潮一区二区三区| 国产精品伦理在线| 一本色道久久加勒比精品| 一区二区三区四区在线播放 | 亚洲综合色网站| 欧美日韩中文一区| 日本aⅴ免费视频一区二区三区| 日韩免费视频线观看| 国产综合色视频| 欧美极品美女视频| eeuss鲁片一区二区三区| 亚洲视频免费看| 欧美日韩不卡一区二区| 久久国产精品72免费观看| 国产日韩欧美制服另类| 91视频xxxx| 婷婷综合五月天| 欧美精品一区二区三区高清aⅴ| 国产成人综合网| 亚洲黄色小说网站| 日韩欧美美女一区二区三区| 国产福利一区在线| 亚洲另类在线制服丝袜| 日韩亚洲欧美在线| 成人激情黄色小说| 五月天激情综合网| 久久久久久久久免费| 91在线视频在线| 婷婷综合五月天| 日本一区二区成人| 欧美日韩视频一区二区| 国产精品18久久久久久久久| 亚洲欧美二区三区| 9191久久久久久久久久久| 国产成人免费在线视频| 亚洲va国产天堂va久久en| 久久蜜桃av一区精品变态类天堂| 99re成人精品视频| 男人的j进女人的j一区| 亚洲欧美日韩系列| 久久蜜臀精品av| 欧美日韩一区三区四区| 成人精品在线视频观看| 日本vs亚洲vs韩国一区三区二区 | 26uuu精品一区二区| 99精品偷自拍| 蜜臀av一区二区| 亚洲精品国产视频| 久久你懂得1024| 6080日韩午夜伦伦午夜伦| www.在线成人| 久久精品av麻豆的观看方式| 亚洲综合在线视频| 欧美经典一区二区| 精品第一国产综合精品aⅴ| 欧美日韩亚洲综合在线| av在线免费不卡| 国产精品中文字幕一区二区三区| 亚洲国产精品一区二区久久|