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

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

?? test.c

?? 用LR分析法實現語法與語義的分析
?? C
字號:
/****************************************/
/*	程序名稱:	LR(0)分析程序			*/
/*	程序用途:	編譯原理實驗(五)		*/
/*	編寫日期:	2005年11月22日			*/
/*	實驗題目:	對下列文法				*/
/*				E->E+T|T				*/
/*				T->T*F|F				*/
/*				F->(E)|i				*/
/*				LR(0)分析程序			*/
/*	程序版本:	1.0	Final				*/
/*	程序作者:	黃記瑤 B0226047			*/
/*	作者郵箱:	hjy2920@163.com			*/
/****************************************/

/********************************************************/
/*		            程序相關說明						*/
/*      	0=+ 1=* 2=( 3=) 4=i 5=# 6=E 7=T 8=F			*/
/*														*/
/*			        	LR(0)分析表						*/
/*	--|----|----|----|-----|----|-----|---|----|----|	*/
/*	  |  + |  * |  ( |  )  |  i |  #  | E |  T | F  | 	*/
/*	0 |    |    | S4 |     | S5 |     | 1 |  2 | 3  |	*/
/*	1 | S6 |    |    |     |    | Acc |   |    |    |	*/
/*	2 | R2 | S7 | R2 | R2  | R2 | R2  |   |    |	|	*/
/*	3 | R4 | R4 | R4 | R4  | R4 | R4  |   |    |	|	*/
/*	4 |    |    | S4 |     | S5 |     | 8 |  2 | 3  |	*/
/*	5 | R6 | R6 | R6 | R6  | R6 | R6  |   |    |	|	*/
/*	6 |    |    | S4 |     | S5 |     |   |  9 | 3  |	*/
/*	7 |    |    | S4 |     | S5 |     |   |    | 10 |	*/
/*	8 | S6 |    |    | S11 |    |     |   |    |	|	*/
/*	9 | R1 | S7 | R1 | R1  | R1 | R1  |   |    |	|	*/
/* 10 | R3 | R3 | R3 | R3  | R3 | R3  |   |    |	|	*/
/* 11 | R5 | R5 | R5 | R5  | R5 | R5  |   |    |	|	*/
/*	--|----|----|----|-----|----|-----|---|----|----|	*/
/********************************************************/

#include "stdio.h"
#include "malloc.h"
#include "math.h"

struct Lchar{
	char char_ch;
	struct Lchar *next;
}Lchar,*p,*h,*temp,*top,*base;
struct Lint{
	int int_t;
	struct Lint *next;
}Lint,*itop,*ibase,*itemp;

int table[12][9]={{0,0,-4,0,-5,0,1,2,3},
				{-6,0,0,0,0,100,0,0,0},
				{12,-7,12,12,12,12,0,0,0},
				{14,14,14,14,14,14,0,0,0},
				{0,0,-4,0,-5,0,8,2,3},
				{16,16,16,16,16,16,0,0,0},
				{0,0,-4,0,-5,0,0,9,3},
				{0,0,-4,0,-5,0,0,0,10},
				{-6,0,0,-11,0,0,0,0,0},
				{11,-7,11,11,11,11,0,0,0},
				{13,13,13,13,13,13,0,0,0},
				{15,15,15,15,15,15,0,0,0}};
/*存儲LR(0)分析表,大于10為歸約,小于0為進棧,0表示出錯,1到10表示狀態轉移,100表示接受*/

char curchar;
char curtocmp;
int curstate;
int right;/*設置開關項,當出錯時為0*/
int i,j;

void push(char pchar)/*字符棧入棧函數*/
{
	temp=malloc(sizeof(Lchar));
	temp->char_ch=pchar;
	temp->next=top;
	top=temp;
}

void pop(void)/*字符棧出棧函數*/
{
	if(top->next!=NULL)
		top=top->next;
}

void ipop(void)/*狀態棧出棧函數*/
{
	if(itop->next!=NULL)
		itop=itop->next;
}

void ipush(int pint)
{
	itemp=malloc(sizeof(Lint));
	itemp->int_t=pint;
	itemp->next=itop;
	itop=itemp;
}

int changchartoint(char ch)/*將字符轉為數字,以得到算符優先值*/
{
	int t;
	switch(ch)
	{
		case '+':t=0;break;
		case '*':t=1;break;
		case '(':t=2;break;
		case ')':t=3;break;
		case 'i':t=4;break;
		case '#':t=5;break;
		case 'E':t=6;break;
		case 'T':t=7;break;
		case 'F':t=8;break;
	}
	return t;
}

void doforpush(int t)
{
	switch(t)
	{
	case 1:push('E');break;
	case 2:push('E');break;
	case 3:push('T');break;
	case 4:push('T');break;
	case 5:push('F');break;
	case 6:push('F');
	}
}

void dosome(void)
{
	int t;
	printf("\nCharStack\tCharLink\tStateStack\n");
	for(;;)
	{
		curchar=h->char_ch;
		curtocmp=top->char_ch;
		curstate=itop->int_t;
		i=changchartoint(curchar);
		t=table[curstate][i];		
		temp=top;
		printf("\n");
		for(;;)/*打印棧*/
		{
			printf("%c",temp->char_ch);
			if(temp->char_ch=='#')
				break;
			else
				temp=temp->next;
		}
		printf("\t");
		temp=h;
		for(;;)/*打印待比較的字符*/
		{
			printf("%c",temp->char_ch);		
			if(temp->char_ch=='#')
				break;
			else
				temp=temp->next;
		}
		printf("\t");
		itemp=itop;
		for(;;)/*打印狀態棧*/
		{
			printf("%d",itemp->int_t);		
			if(itemp->next==NULL)
				break;
			else
				itemp=itemp->next;
		}
		printf("\t");
		if(t==0)/*LR(0)分析表為0,出錯*/
		{
			right=0;
			break;			
		}
		else/*LR(0)分析表不為0*/
		{
			if(t<0)/*LR(0)分析表小于0,入棧*/
			{
				push(curchar);  /*字符入字符棧*/
				ipush(abs(t));  /*狀態棧入棧*/
				h=h->next;
			}
			else/*LR(0)分析表大于0,歸約*/
			{
				if(t==100)/*LR(0)分析表等于100,正確*/
					break;
				if(t==12||t==14||t==16)/*產生式右部和狀態出棧*/
				{
					pop();
					ipop();
				}
				else
				{
					pop();pop();pop();
					ipop();ipop();ipop();
				}                      /*產生式右部和狀態出棧*/
				doforpush(t-10);/*產生式左部出棧*/
				j=changchartoint(top->char_ch);
				curstate=itop->int_t;
				ipush(table[curstate][j]);/*狀態轉移,狀態入棧*/
			}
		}
	}
}
void main(void)
{
	char ch;
	base=malloc(sizeof(Lchar));
	base->next=NULL;
	base->char_ch='#';
	top=base;/*初始化字符棧*/
	ibase=malloc(sizeof(Lint));
	ibase->int_t=0;
	ibase->next=NULL;
	itop=ibase;/*初始化狀態棧*/
	h=malloc(sizeof(Lchar));
	h->next=NULL;
	p=h;
	do{				/*輸入待比較字符串,以'#'結束*/
		ch=getch();
		putch(ch);
		if(ch=='i'||ch=='+'||ch=='*'||ch=='('||ch==')'||ch=='#')/*輸入合法字符串*/
		{
			temp=malloc(sizeof(Lchar));
			temp->next=NULL;
			temp->char_ch=ch;
			h->next=temp;
			h=h->next;
		}
		else/*輸入不合法字符串*/
		{
			temp=p->next;
			printf("\nInput a wrong char!Input again:\n");
			for(;;)/*打印當前字符串*/
			{				
				if (temp!=NULL)
					printf("%c",temp->char_ch);						
				else
					break;
				temp=temp->next;
			}
		}
	}while(ch!='#');/*輸入待比較字符串,以'#'結束*/
	p=p->next;
	h=p;
	right=1;/*初始化開關項*/
	dosome();/*開始識別*/
	if(right)
		printf("\nOK!\n");
	else
		printf("\nError!\n");
	getch();
}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
久久久久久亚洲综合| 欧美videossexotv100| 天天色图综合网| 日韩三区在线观看| 大白屁股一区二区视频| 亚洲综合图片区| 欧美一级搡bbbb搡bbbb| 国产精品资源网站| 亚洲人精品午夜| 在线成人午夜影院| 成人久久久精品乱码一区二区三区 | 亚洲激情五月婷婷| 欧美精品一级二级三级| 国产高清精品久久久久| 亚洲综合成人在线视频| 亚洲精品一区二区精华| 91蜜桃婷婷狠狠久久综合9色| 午夜久久久久久| 精品国产一二三| 在线精品视频免费观看| 国内一区二区视频| 午夜久久电影网| 中文字幕一区不卡| 精品精品欲导航| 91久久精品国产91性色tv | 26uuu国产在线精品一区二区| www.在线成人| 极品少妇一区二区三区精品视频| 亚洲女同女同女同女同女同69| 精品少妇一区二区三区免费观看 | 欧美电影一区二区| 一本大道久久a久久综合婷婷| 久久国产福利国产秒拍| 亚洲国产精品欧美一二99| 日本一区二区三区国色天香| 欧美一级在线观看| 色综合欧美在线视频区| 国产91精品免费| 久久国产欧美日韩精品| 午夜激情一区二区| 亚洲卡通欧美制服中文| 日本一区二区在线不卡| 精品1区2区在线观看| 欧美日韩免费不卡视频一区二区三区| zzijzzij亚洲日本少妇熟睡| 国产麻豆日韩欧美久久| 麻豆免费精品视频| 亚洲综合小说图片| 亚洲欧美另类综合偷拍| 中日韩av电影| 久久精品亚洲乱码伦伦中文| 欧美一级免费观看| 欧美日韩免费不卡视频一区二区三区 | 韩国精品主播一区二区在线观看| 亚洲欧美日韩一区二区 | 精品国产凹凸成av人导航| 69p69国产精品| 欧美片在线播放| 欧美日韩三级一区| 欧美日韩国产成人在线免费| 欧美在线短视频| 在线看日韩精品电影| 99久久精品一区二区| 日本成人在线看| 五月综合激情日本mⅴ| 亚洲123区在线观看| 午夜日韩在线观看| 午夜天堂影视香蕉久久| 午夜一区二区三区视频| 天天av天天翘天天综合网色鬼国产 | 蜜桃一区二区三区在线观看| 日韩激情av在线| 天天av天天翘天天综合网| 日本在线不卡视频| 紧缚奴在线一区二区三区| 国产精品自拍av| 粉嫩av一区二区三区在线播放| 国产精品一区二区在线看| 国产成人精品免费| 波多野结衣欧美| 色哟哟一区二区三区| 欧美亚洲日本国产| 亚洲三级在线免费观看| 一区二区三区成人在线视频| 三级亚洲高清视频| 国产一区视频网站| 99久久伊人精品| 欧美性生活影院| 欧美一区二区成人| 欧美国产欧美综合| 亚洲午夜视频在线| 久久黄色级2电影| 成人性色生活片免费看爆迷你毛片| 成人免费观看av| 在线亚洲免费视频| 欧美一级在线免费| 久久久久国产成人精品亚洲午夜| 中文在线免费一区三区高中清不卡| 一区在线观看免费| 日韩中文字幕亚洲一区二区va在线 | 国产综合色在线| 97成人超碰视| 欧美片在线播放| 久久久精品黄色| 亚洲五码中文字幕| 蜜臀久久99精品久久久画质超高清 | www.av精品| 91精品欧美久久久久久动漫| 国产女同互慰高潮91漫画| 一区二区三区四区在线免费观看| 亚洲gay无套男同| 岛国一区二区三区| 欧美男女性生活在线直播观看| 久久久影视传媒| 亚洲中国最大av网站| 国产一区二三区| 色婷婷综合久久久| 久久婷婷成人综合色| 亚洲精品国产a| 国产精品99久久不卡二区| 在线一区二区三区四区| 久久久久久久久久久久久夜| 亚洲成人手机在线| 成人亚洲精品久久久久软件| 91精品婷婷国产综合久久性色 | 久久美女高清视频| 亚洲黄色免费电影| 国产成人综合视频| 91精品国产乱码久久蜜臀| 国产精品女同一区二区三区| 久久精品噜噜噜成人av农村| 在线观看精品一区| 国产精品久久久久久久久动漫 | 秋霞国产午夜精品免费视频| 91免费视频网| 日本一区二区三区免费乱视频| 一区在线观看免费| 成人av在线看| 国产精品久久久久久福利一牛影视| 激情五月婷婷综合| 久久免费看少妇高潮| 精品在线免费视频| 久久久久高清精品| 国产成a人亚洲精品| 国产精品天干天干在线综合| 成人免费av资源| 亚洲欧美另类综合偷拍| 91福利在线免费观看| 亚洲成人激情自拍| 91精品国产91久久久久久最新毛片| 三级久久三级久久久| 日韩限制级电影在线观看| 久久99久久99精品免视看婷婷| 精品噜噜噜噜久久久久久久久试看| 久久国产精品一区二区| 精品捆绑美女sm三区| 国产精品69毛片高清亚洲| 久久久精品日韩欧美| www.亚洲在线| 亚洲国产精品一区二区www| 91精品国产综合久久久久久久久久| 琪琪久久久久日韩精品| 精品国产污污免费网站入口| 丁香亚洲综合激情啪啪综合| 亚洲丝袜精品丝袜在线| 欧美视频你懂的| 蜜臀久久久99精品久久久久久| 久久久久青草大香线综合精品| 99免费精品在线| 午夜视黄欧洲亚洲| 久久精品视频一区二区| 91福利在线导航| 九九九久久久精品| 中文字幕日韩av资源站| 91.com视频| 成人美女视频在线观看| 亚洲精选视频在线| 日韩欧美精品在线| 懂色av一区二区三区蜜臀| 亚洲成人免费av| 国产日本亚洲高清| 欧美日韩激情一区| 国产成a人亚洲| 亚欧色一区w666天堂| 国产人成亚洲第一网站在线播放| 国产精品视频看| 欧美日韩美少妇| 成人听书哪个软件好| 亚洲第一激情av| 久久久精品国产免费观看同学| 欧洲激情一区二区| 福利一区在线观看| 午夜精品福利在线| 中文字幕欧美一区| 久久综合九色综合欧美亚洲| 91麻豆国产自产在线观看| 久久99国产精品成人| 亚洲一区二区综合| 国产精品丝袜久久久久久app| 欧美一区二区三区白人|