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

? 歡迎來(lái)到蟲(chóng)蟲(chóng)下載站! | ?? 資源下載 ?? 資源專(zhuān)輯 ?? 關(guān)于我們
? 蟲(chóng)蟲(chóng)下載站

?? zhanghui.cpp

?? 詞法分析
?? CPP
字號(hào):
#include<ctype.h>
#include<stdlib.h>
#include<iomanip>
#include<string>
#include<iostream.h>
struct danci
  {
	  int id;			//單詞種別
	  char name[10];	//單詞屬性值
  };
int fout[20];
int index=1;
int G_table[9][6];
int k[20];
int n=0;
danci word[20];
int boo(int);
int compare(int);
int not(int);
int forid(int);
typedef struct node{
	int data; 
   	node* next;
 }* link;
link insert(link stack,int n)//向前插入鏈表
{
	link newnode;
	newnode=new node;
	if(!newnode)
	{
		cout<<"error!"<<endl;
		exit(0);
	}
	newnode->data=n;
	newnode->next=stack;
	stack=newnode;
	return stack;
}
link del(link stack,int &value)//刪除鏈表元素
{
	link top;
	if(stack)
	{
		top=stack;
		stack=stack->next;
		value=top->data;
		delete top;
		return stack;
	}
	value=-1;
	return NULL;
}
void error()
{
	cout<<"詞法錯(cuò)誤,標(biāo)志符不能以數(shù)字開(kāi)頭"<<endl;
	exit(0);
}
void error1()
{
	cout<<"語(yǔ)法錯(cuò)誤,輸入正確句子"<<endl;
	exit(0);
}
int not(int i)
{
	int ii;
	i=forid(i);
	while(word[i].id==3)
	{
		ii=i;
		i++;
		i=forid(i);
		fout[index]=ii;
		index++;
	}
	return i;
}
void init()//初始化文法矩陣
{
	for(int i=0;i<9;i++)               	
	for(int j=0;j<6;j++)
		G_table[i][j]=-1;
	G_table[0][0]=0;G_table[0][1]=1; //初始化文法表
	G_table[1][0]=1;G_table[1][1]=1;G_table[1][2]=5;G_table[1][3]=2;
	G_table[2][0]=1;G_table[2][1]=2;
	G_table[3][0]=1;G_table[3][1]=1;G_table[3][2]=3;
	G_table[4][0]=2;G_table[4][1]=3;
	G_table[5][0]=3;G_table[5][1]=6;G_table[5][2]=3;
	G_table[6][0]=3;G_table[6][1]=9;G_table[6][2]=1;G_table[6][3]=10;
	G_table[7][0]=3;G_table[7][1]=7;
	G_table[8][0]=3;G_table[8][1]=9;G_table[8][2]=7;G_table[8][3]=8;
	G_table[8][4]=7;G_table[8][5]=10;
}
void print()//打印文法
{   
char a0[]="E";char a1[]="S";
char a2[]="B";char a3[]="C";
char a4[]="and";char a5[]="or";
char a6[]="not";char a7[]="id";
char a8[]="relop";char a9[]="(";
char a10[]=")";
cout<<"本實(shí)驗(yàn)的文法為:"<<endl;
cout<<a0<<"->"<<a1<<endl;
cout<<a1<<"->"<<a1<<' '<<a5<<a2<<endl;
cout<<a1<<"->"<<a2<<endl;
cout<<a2<<"->"<<a2<<' '<<a4<<' '<<a3<<endl;
cout<<a2<<"->"<<a3<<endl;
cout<<a3<<"->"<<a6<<' '<<a3<<endl;
cout<<a3<<"->"<<a9<<a1<<a10<<endl;
cout<<a3<<"->"<<a7<<endl;
cout<<a3<<"->"<<a9<<a7<<' '<<a8<<' '<<a7<<a10<<endl; 
}
int  lex(char * buf)//詞法分析
{
	int i=0,j=0;
	int n=0;
	char Temp_name[10];
	while(buf[i]!='\0')
	{
		if(buf[i]==' '||buf[i]=='\n')
			i++;
		else if(isalpha(buf[i])||buf[i]=='_')//標(biāo)志符判斷
		{
			Temp_name[j]=buf[i];
			i++;
			while(isalnum(buf[i]))
			{
				j++;
				Temp_name[j]=buf[i];
				i++;
			}
		   // if
			memcpy(word[n].name,Temp_name,j+1);
			word[n].name[j+1]='\0';
			if(strcmp(word[n].name,"and")==0)
				word[n].id=1;
			else if(strcmp(word[n].name,"or")==0)
				word[n].id=2;
			else if(strcmp(word[n].name,"not")==0)
				word[n].id=3;
			else 
				word[n].id=0;
			n++;
			j=0;
		}
		else if(isdigit(buf[i]))//數(shù)字判斷
		{
			while(isdigit(buf[i]))
			{
			Temp_name[j]=buf[i];
			i++;
			j++;
			}
				if(isalpha(buf[i]))
                  error();
			memcpy(word[n].name,Temp_name,j+1);
			word[n].name[j]='\0';
			n++;
			j=0;
		}
		else//運(yùn)算符號(hào)判斷
		{
			switch(buf[i])
			{
				case '>':if(buf[i+1]=='=')
						 {
							  i++;
						   	  word[n].id=8;
							  strcpy(word[n].name,">=");
						 }
						 else
						 {
							 word[n].id=4;
							 strcpy(word[n].name,">");
						 }
						 n++;break;
				case '<':if(buf[i+1]=='=')
						 {
							  i++;
						   	  word[n].id=9;
							  strcpy(word[n].name,"<=");
						 }
						 else 
						 {
							 word[n].id=5;
							 strcpy(word[n].name,"<");
						 }
						 n++;break;
				case '=': word[n].id=6;strcpy(word[n].name,"=");n++;break;
				case '!': if(buf[i+1]=='=')
						  {
							  i++;
						   	  word[n].id=7;strcpy(word[n].name,"!=");
							  n++;
						  }
						   break;
				case '(': word[n].id=10;strcpy(word[n].name,"(");n++;break;
				case ')': word[n].id=11;strcpy(word[n].name,")");n++;break;
			}
			i++;
		}
	}
	strcpy(word[n].name,"#");
		word[n].id=999;
	return n;//單詞符號(hào)個(gè)數(shù)
}

void gram(int * kind)
{
	int n=0;
	link state;	                    
	link lex;                      
	link operate;						
	link ID;						
	state=new node[30];lex=new node[15];
	if(!state||!lex)                
	{
		cout<<"over stack! "<<endl;
		exit(0);
	}
	int trace=0;					
	int G[9][5];					
	int Stable[16][11];			//SLR分析表
	int i,j;
	for(i=0;i<9;i++)               	
		for(j=0;j<5;j++)
			G[i][j]=-1;
	for(i=0;i<18;i++)
		for(j=0;j<11;j++)
			Stable[i][j]=0;		//初始化SLR表,其中表的初值為0,表示出錯(cuò)!								
	//設(shè)置SLR表 1-17表示移進(jìn),n進(jìn)狀態(tài)棧;21-29表示按N-20個(gè)產(chǎn)生式規(guī)約;0表示出錯(cuò)
	Stable[0][2]=4;Stable[0][3]=5;Stable[0][6]=6;
	Stable[0][8]=1;Stable[0][9]=2;Stable[0][10]=3;
	Stable[1][0]=7;Stable[1][7]=111;
	Stable[2][0]=23;Stable[2][1]=8;Stable[2][4]=23;Stable[2][7]=23;
	Stable[3][0]=25;Stable[3][1]=25;Stable[3][4]=25;
	Stable[3][7]=25;
	Stable[4][2]=4;Stable[4][3]=5;Stable[4][6]=6;Stable[4][10]=9;
	Stable[5][2]=4;Stable[5][3]=5;Stable[5][6]=11;
	Stable[5][8]=10;Stable[5][9]=2;Stable[5][10]=3;
	Stable[6][0]=28;Stable[6][1]=28;Stable[6][4]=28;Stable[6][7]=28;
	Stable[7][2]=4;Stable[7][3]=5;Stable[7][6]=6;
	Stable[7][9]=12;Stable[7][10]=3;
	Stable[8][2]=4;Stable[8][3]=5;	Stable[8][6]=6;Stable[8][10]=13;
	Stable[9][0]=26;Stable[9][7]=26;Stable[9][4]=26;Stable[9][1]=26;
	Stable[10][0]=7;Stable[10][4]=14;
	Stable[11][0]=28;Stable[11][1]=28;
	Stable[11][4]=28;Stable[11][5]=15;Stable[11][7]=28;
	Stable[12][0]=22;Stable[12][1]=8;Stable[12][4]=22;Stable[12][7]=22;
	Stable[13][1]=4;Stable[13][2]=4;Stable[13][3]=4;
	Stable[13][0]=24;Stable[13][1]=24;Stable[13][4]=24;Stable[13][7]=24;
	Stable[14][0]=27;Stable[14][1]=27;Stable[14][4]=27;Stable[14][7]=27;
	Stable[15][6]=16;Stable[16][6]=17;
	Stable[17][0]=29;Stable[17][1]=29;Stable[17][4]=29;Stable[17][7]=29;
	kind[n]=7;								//輸入串最后字符為#
	n++;
	state=insert(state,0);
	lex=insert(lex,7);
	int a;
	int staTop;								//存放狀態(tài)棧的棧頂元素
	int operater;int ch1=0;int ch2;
	for(a=0;a<n;a++)						//進(jìn)行SLR分析
	{
		staTop=state->data;
	  if(Stable[staTop][kind[a]]==0)
		{

			break;
				
		}
	 else if(Stable[staTop][kind[a]]<20)
		{			//規(guī)約
			int sta1;
			int letter1;
			if(state!=NULL)
				state=del(state,sta1);
			else 
			{
             error1();
			}
			int num=0;					//出棧次數(shù)
			int b;
			for(b=1;b<G_table[Stable[staTop][kind[a]]][4];b++)
			{							//規(guī)約式右部出棧
				lex=del(lex,letter1);
				num++;
			}
			lex=insert(lex,G_table[Stable[staTop][kind[a]]][0]);//規(guī)約式左部進(jìn)棧
			for(b=1;b<num;b++)			//狀態(tài)棧中再出棧num-1個(gè)狀態(tài)
				state=del(state,sta1);
			int staTop1;
			staTop1=state->data;
			state=insert(state,Stable[staTop1][G_table[Stable[staTop][kind[a]]][0]]-50);
			a--;
			if(num>1)
			{	
				if(ch1==0)//總結(jié)符
				{
					ID=del(ID,ch1);
					ch1=trace;trace--;
				}
				else
					ch1=-1;
				operate=del(operate,operater);
				ID=del(ID,ch2);
				ch2=trace;trace--;
				ch1--;
			}
		}
    	else if(Stable[staTop][kind[a]]<50)
		{//移進(jìn)一個(gè)符號(hào)
			state=insert(state,Stable[staTop][kind[a]]-20);
			lex=insert(lex,kind[a]);
			if(kind[a]==0)
			{
				trace++;
				ID=insert(ID,kind[a]);
			}
			else
				operate=insert(operate,kind[a]);
		}
		else if(Stable[staTop][kind[a]]==99)
		{
			cout<<endl;
			cout<<"ACCEPT!"<<endl;
			break;
		}
	
	}
}
void forboland(int length)
{
	
	int i=0;
	while((i<length)&&(word[i].id!=99))
	{
		i=boo(i);
		if(word[i].id==99)
		{
         error1();
		}
	}

}
int boo (int i)
{
	int ii;
	i=compare(i);
	while (word[i].id==1||word[i].id==2)
	{
		ii=i;
		i++;				
		i=compare(i);	
		fout[index]=ii;//
		index++;
	}
	return i;
}

int forid(int i)
{
	if (word[i].id==0)		
	{
		fout[index]=i;
		index++;
		i++;
	}
    else
	{
		if(word[i].id==10)
		{
			i++;				
			i=boo(i);
			if (word[i].id==11)
				i++;			
			else
				word[i].id=99;
		}
		else if(word[i].id==3)
		{;}
		else
		{
            error1();
			word[i].id=99;
		}
	}
	return i;
}
void boland()
{
	for(int i=1;i<index;i++)
	{
		if(word[fout[i]].id==0)
			cout<<word[fout[i]].name<<" ";
		else
		{
			switch (word[fout[i]].id)
			{
			case 1: cout<<"and ";break;
			case 2: cout<<"or ";break;
			case 3: cout<<"not ";break;
			case 4: cout<<"> ";break;
			case 5: cout<<"< ";break;
			case 6: cout<<"= ";break;
			case 7: cout<<"!= ";break;
			case 8: cout<<">= ";break;
			case 9: cout<<"<= ";break;
			}
		}
	}
	index=0;
 }
int compare(int i)
{
	int ii;
	i=not(i);
	while(word[i].id==4||word[i].id==5||word[i].id==6
		||word[i].id==7||word[i].id==8||word[i].id==9)
	{
		ii=i;
		i++;				
		i=not(i);
		fout[index]=ii;
		index++;
	}
	return i;
}
void main()
{
	char buffer[30];
	int i=0;
	int length;
	char *inword;
	init();
	print();
	cout<<"輸入布爾表達(dá)式,以#結(jié)束 :"<<endl;
	cin>>buffer[i];
	while(buffer[i]!='#')
	{
		i++;
		cin.get(buffer[i]);
	}
	buffer[i]='\0';
	length=i+1;
	inword=new char[length];
	memcpy(inword,buffer,length);
	length=lex(inword);
	cout<<"詞法分析結(jié)果如下:"<<endl;
	cout<<'('<<"屬性"<<' '<<"值"<<')';
	for( i=0;i<length;i++)
	{	cout<<'('<<word[i].id<<' '<<word[i].name<<')'; cout<<' ';}
	cout<<endl;

	n=length;
	forboland(length);
	gram(k);
	cout<<"逆波蘭式為:\n"<<endl;
	//逆波蘭式翻譯
	boland();
	cout<<endl;
}
  
  
 

?? 快捷鍵說(shuō)明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號(hào) Ctrl + =
減小字號(hào) Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
亚洲乱码中文字幕综合| 一区二区三区高清不卡| 国产99久久久国产精品免费看| 91日韩在线专区| 欧美一级xxx| 99精品久久只有精品| 亚洲一区二区精品久久av| 8x8x8国产精品| 国产高清一区日本| 国产精品久久久久久妇女6080 | 欧美一区二区不卡视频| 大白屁股一区二区视频| 日韩精品亚洲一区二区三区免费| 亚洲精品在线电影| 日本精品视频一区二区| 成人动漫在线一区| 久久精品久久综合| 亚洲国产精品久久久男人的天堂| 国产精品久久午夜| 久久久久久久一区| 在线不卡免费av| 色婷婷av一区二区三区gif | 欧美日韩精品电影| 精彩视频一区二区| 欧美a一区二区| 亚洲美女视频在线观看| 国产精品你懂的在线| 久久中文字幕电影| 欧美老肥妇做.爰bbww| av成人老司机| 色综合中文字幕国产 | 香港成人在线视频| 自拍偷拍国产亚洲| 亚洲少妇最新在线视频| 在线91免费看| 日韩免费在线观看| 欧美一区二区成人6969| 精品国产三级电影在线观看| 日韩午夜在线观看| 欧美二区在线观看| 91精品国产欧美一区二区成人 | 色噜噜偷拍精品综合在线| 色婷婷av一区二区三区大白胸| 色综合久久中文字幕综合网 | 中文字幕在线观看不卡视频| 久久久一区二区三区| 亚洲一本大道在线| 成人精品国产一区二区4080| 日韩亚洲国产中文字幕欧美| 亚洲欧美区自拍先锋| 国产资源精品在线观看| 欧美精品久久一区| 一区二区视频在线看| 国产一区二区三区在线观看精品| 在线精品视频免费播放| 国产日产亚洲精品系列| 亚洲成人av福利| 91麻豆精品一区二区三区| 2021中文字幕一区亚洲| 毛片av一区二区| 欧美日韩国产另类不卡| 一区二区三区91| 白白色亚洲国产精品| 国产欧美一区二区精品性| 精品中文字幕一区二区小辣椒| 欧美精品色综合| 亚洲曰韩产成在线| 在线免费观看日韩欧美| 亚洲欧美日韩国产综合在线 | 中文字幕亚洲欧美在线不卡| 国产精品99久久久久| 精品国产乱码久久久久久1区2区 | 久久一区二区三区国产精品| 奇米影视7777精品一区二区| 欧美人伦禁忌dvd放荡欲情| 亚洲国产精品嫩草影院| 欧美日韩你懂得| 亚洲成a人片在线不卡一二三区 | 精品午夜久久福利影院| 精品福利在线导航| 国产精品一区二区不卡| 久久久综合网站| 成人综合在线视频| 亚洲国产精华液网站w| 国产成人综合网| 国产日韩欧美精品综合| voyeur盗摄精品| 偷拍日韩校园综合在线| 欧美日韩色综合| 日本麻豆一区二区三区视频| 日韩一区国产二区欧美三区| 六月丁香综合在线视频| 久久夜色精品国产欧美乱极品| 国产成人av自拍| 国产精品国产三级国产普通话99| 99久久久久久99| 午夜精品影院在线观看| 精品国产乱码久久久久久浪潮| 国产精品 欧美精品| 国产精品国产自产拍高清av王其 | 久久99国产精品久久| 久久久777精品电影网影网| 豆国产96在线|亚洲| ㊣最新国产の精品bt伙计久久| 在线观看日韩电影| 美腿丝袜亚洲色图| 国产欧美日韩另类视频免费观看| 91在线视频播放地址| 日日摸夜夜添夜夜添精品视频| 欧美一区二区日韩| 波多野结衣精品在线| 一区二区国产盗摄色噜噜| 欧美成人一区二区三区| 97se亚洲国产综合自在线观| 日本视频免费一区| 国产精品国产三级国产aⅴ无密码| 在线观看91av| 99综合影院在线| 久久99国产精品尤物| 亚洲一二三区不卡| 国产精品私人自拍| 欧美一区二区精品在线| 99在线热播精品免费| 国产又粗又猛又爽又黄91精品| 亚洲成年人网站在线观看| 国产精品网曝门| 日韩精品一区二区在线| 欧美性生活一区| 国产麻豆视频一区| 男人的j进女人的j一区| 综合色天天鬼久久鬼色| 在线成人午夜影院| 丁香一区二区三区| 精品亚洲国产成人av制服丝袜 | 国产精品免费视频网站| 欧美日韩综合在线免费观看| www.在线欧美| 国产成人超碰人人澡人人澡| 精品综合免费视频观看| 视频一区二区国产| 亚洲人妖av一区二区| 欧美激情在线一区二区| 欧美一区二区三区免费大片| 91福利国产精品| 91免费版在线| av一本久道久久综合久久鬼色| 蜜桃在线一区二区三区| 亚洲激情欧美激情| 一区二区三区中文在线观看| 亚洲精品一二三区| 亚洲国产精品v| 日韩欧美一区二区久久婷婷| 欧美午夜电影一区| 欧美中文字幕一区二区三区亚洲| av电影在线观看不卡| 午夜精品久久久久| 性做久久久久久免费观看| 亚洲国产成人91porn| 亚洲精品日韩专区silk| 亚洲视频在线一区二区| 国产日韩精品视频一区| 久久综合九色综合欧美就去吻| 欧美偷拍一区二区| 欧美日本国产视频| 欧美三级三级三级爽爽爽| 激情国产一区二区| 轻轻草成人在线| 狠狠色综合色综合网络| 美女mm1313爽爽久久久蜜臀| 丝袜美腿亚洲一区二区图片| 欧美aa在线视频| 国产二区国产一区在线观看| 成人黄动漫网站免费app| 99精品视频在线观看免费| 91福利视频久久久久| 这里只有精品电影| 国产视频一区在线观看| 亚洲天堂2014| 日韩av中文在线观看| 国产精品一区专区| 99久久99久久综合| 欧美亚洲图片小说| 欧美一区二区人人喊爽| 国产亚洲精品bt天堂精选| 亚洲婷婷综合久久一本伊一区| 一区二区三区欧美久久| 麻豆国产精品一区二区三区| 国产宾馆实践打屁股91| 色偷偷成人一区二区三区91| 欧美在线影院一区二区| 精品国产乱码久久久久久1区2区 | 精品奇米国产一区二区三区| 国产精品对白交换视频| 三级在线观看一区二区| 国产成人h网站| 欧美日韩一级黄| 国产精品婷婷午夜在线观看| 午夜欧美视频在线观看| 岛国一区二区在线观看| 欧美肥大bbwbbw高潮|