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

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

?? cpp1.cpp

?? 語法分析程序 必須先編寫一個(gè)program的文本文件 再對(duì)該文本文件的程序進(jìn)行語法分析
?? CPP
字號(hào):
#include <iostream>
#include <string>
#include <fstream>
using namespace std;

int code[100];
int sym,flag=1,m=0;//flag判斷錯(cuò)誤,1為真,0為假。sym當(dāng)前字符
bool isNum(char );
bool isWrd(char );
int isKeywrd(char s[]); 
int isDoublewrd(char c);

/*==============語法分析函數(shù)======================*/
int program();
void proghead();
void block();
int consexpl();
void consdefi();
int conssuff();
int varexl();
void vandefi();
int idsuff();
int varssuff();
void typeil();
int procdefi();
void procedh();
int argument();
int procsuff();
int sentence();
void assipro();
int suffix();
void ifsent();
void whilsent();
void read();
void write();
int exprsuff();
void compsent();
int sentsuff();
void conditio();
void express();
int termsuff();
void term();
int factsuff();
void factor();
void addoper();
void muloper();
int respoper();

const char Key1[]={'p','r','o','g','r','a','m'}; 
const char Key2[]="const";   
const char Key3[]="var";   
const char Key4[]="integer";   
const char Key5[]="long";   
const char Key6[]="procedure";
const char Key7[]="if";
const char Key8[]="then";
const char Key9[]="while";
const char Key10[]="do";
const char Key11[]="read";
const char Key12[]="write";
const char Key13[]="begin";
const char Key14[]="end";
const char Key15[]="odd";

bool isNumch(char c)
{
	return (c>='0' && c<='9');
}

bool isWrdch(char c)
{
	return (c>='a' && c<='z');
}

int isKeywrd(char s[])
{
	int i=0;
	while(s[i]==Key1[i] && (s[i]!=0 && Key1[i]!=0)) i++;
	if(s[i]==Key1[i]) return 1;
	else 
	{
		i=0; 
		while(s[i]==Key2[i] && (s[i]!=0 && Key2[i]!=0)) i++;
		if(s[i]==Key2[i]) return 2;
		else
		{
			i=0;
	 		while(s[i]==Key3[i] && (s[i]!=0 && Key3[i]!=0)) i++;
	     	if(s[i]==Key3[i]) return 3;
			else
			{
				i=0;
	 	    	while(s[i]==Key4[i] && (s[i]!=0 && Key4[i]!=0)) i++;
	        	if(s[i]==Key4[i]) return 4;
				else
				{
					i=0;
	 	         	while(s[i]==Key5[i] && (s[i]!=0 && Key5[i]!=0)) i++;
	            	if(s[i]==Key5[i]) return 5;
					else 
					{
						i=0;
	 	            	while(s[i]==Key6[i] && (s[i]!=0 && Key6[i]!=0)) i++;
	                    if(s[i]==Key6[i]) return 6;
						else
						{
							i=0;
	 	                	while(s[i]==Key7[i] && (s[i]!=0 && Key7[i]!=0)) i++;
	                     	if(s[i]==Key7[i]) return 7;
							else
							{
								i=0;
	 	                    	while(s[i]==Key8[i] && (s[i]!=0 && Key8[i]!=0)) i++;
	                            if(s[i]==Key8[i]) return 8;
					        	else
								{
									i=0;
	 	                         	while(s[i]==Key9[i] && (s[i]!=0 && Key9[i]!=0)) i++;
	                                if(s[i]==Key9[i]) return 9;
					            	else
									{
										i=0;
	 	                                while(s[i]==Key10[i] && (s[i]!=0 && Key10[i]!=0)) i++;
	                                    if(s[i]==Key10[i]) return 10;
				                		else
										{
											while(s[i]==Key11[i] && (s[i]!=0 && Key11[i]!=0)) i++;
	                                        if(s[i]==Key11[i]) return 11;
				                	    	else
											{
												while(s[i]==Key12[i] && (s[i]!=0 && Key12[i]!=0)) i++;
	                                            if(s[i]==Key12[i]) return 11;
				                	        	else
												{
													while(s[i]==Key13[i] && (s[i]!=0 && Key13[i]!=0)) i++;
	                                                if(s[i]==Key13[i]) return 13;
				                	            	else
													{
														while(s[i]==Key14[i] && (s[i]!=0 && Key14[i]!=0)) i++;
	                                                    if(s[i]==Key14[i]) return 14;
				                	                	else
														{
															while(s[i]==Key15[i] && (s[i]!=0 && Key15[i]!=0)) i++;
	                                                        if(s[i]==Key15[i]) return 15;
				                	                      	else return 0;
														}
													}
												}
											}
										}
									}
								}
							}
						}
					}
				}
			}
		}
	}
}

int isDoublewrd(char c)
{
	int x;
	switch(c)
	{
	case '+': x=16;break;
	case '-': x=17;break;
	case '*': x=18;break;
	case '/': x=19;break;
	case '=': x=20;break;
	case '<': x=22;break;
	case '>': x=24;break;
	case ',': x=26;break;
	case '.': x=27;break;
	case ';': x=28;break;
	case ':': x=29;break;
	case '(': x=31;break;
	case ')': x=32;break;
	case '#': x=35;break;
	default: x=0;
	}
	return x;
}


int cifa()
{
	ifstream fin("program.txt");
	char ch;
	char str[25]={0};
	int n,i,val,k=0;
	while(!fin.eof())
	{
		ch=fin.get();
		if(ch==' ' || ch=='\n') continue;
		else if(isWrdch(ch)) 
		{
			n=0;
			while(isWrdch(ch) || isNumch(ch))
			{	 
				if(n<20)
				{
					str[n]=ch;
					n=n+1;
					ch=fin.get();
				}
				else ch=fin.get();
			}
			if(i=isKeywrd(str)) 
			{
				cout<<i<<endl;
				code[k]=i;
				k++;
			}
			else 
			{
				cout<<"34"<<' '<<str<<endl;
				code[k]=34;
				k++;
			}
			if(i=isDoublewrd(ch))
			{
				cout<<i<<endl;
				code[k]=i;
				k++;
			}
			i=0;
			while(str[i]!=0) {str[i]=0;i++;}
		}
		else if(isNumch(ch)) 
		{
			val=0;
			while(isNumch(ch))
			{
				val=val*10+ch-'0';
				ch=fin.get();
			}
			cout<<"33"<<' '<<val<<endl;
			code[k]=33;
			k++;
			if(i=isDoublewrd(ch)) 
			{
				cout<<i<<endl;
				code[k]=i;
				k++;
			}
			i=0;
		}
		else if(isDoublewrd(ch))
		{
			cout<<isDoublewrd(ch)<<endl;
			code[k]=isDoublewrd(ch);
			k++;
		}
	}
	return k;
}
void getword() //************讀取字符
{
	sym=code[m];
	m++;
}
void error() //******************判斷錯(cuò)誤位置
{
	flag=0;
	int t=m-1;
	cout<<"位置:"<<t+1<<"代碼:"<<code[t]<<" "<<"出錯(cuò)"<<endl;
	exit(0);
}

/*=========================================================*/
int program()
{
	getword();
	proghead();
	block();
	if(sym==27) return 0;
	else error();
}
void proghead()
{
	 if(sym==1) 
	 {
		 getword();
		 if(sym==34) 
		 {
			 getword();
			 if(sym==28) getword();
			 else error();
		 }
		 else error();
	 }
	 else error();
}
void block()
{
	consexpl();
	varexl();
	procdefi();
	compsent();
}
int consexpl()
{
	if(sym==2)
	{
		getword();
		consdefi();
		conssuff();
	}
	else return 0;
}
void consdefi()
{
	 if(sym==34) 
	 {
		 getword();
		 if(sym==20) 
		 {
			 getword();
			 if(sym==33) getword();
			 else error();
		 }
		 else error();
	 }
	 else error();
}
int conssuff()
 {
	 if(sym==26) 
	 {
		 getword();
		 consdefi();
		 conssuff();
	 }
	 else return 0;
 }
int varexl()
 {
	 if(sym==3)
	 {
		 getword();
		 vandefi();
		 varssuff();
	 }
	 else return 0; 
 }
void vandefi()
{
	if(sym==34) 
	 {
		getword(); 
		idsuff();
		if(sym==29) 
		 {
			 getword();
			 typeil();
			 if(sym==28) getword();
			 else error();
		 }
		 else error();
	 }
	 else error();

}
int idsuff()
{
	if(sym==26)
	{
		getword();
		if(sym==34) getword();
		else flag=0;
		idsuff();
	}
	else return 0;
}
int varssuff()
{
	if(sym==34) 
	{
		vandefi();
		varssuff();
	}
	else return 0;
}
void typeil()
{
	if(sym==4||sym==5) getword(); 
	else error();
}
int procdefi()
{
	if(sym==6)
	{
		procedh();
		block();
		if(sym==28) 
		{
			getword();
		    procsuff();
		}
		else error();
	}
	else return 0;
}
void procedh()
{
     if(sym==6)
	 {
		 getword();
         if(sym==34) 
		 {
			 getword();
			 argument();
		     if(sym==28) getword();
             else error();
		 }
		 else error();
	 }
	 else error();
}
int argument()
{
     if(sym==31)
	 {
		 getword();
		 if(sym==34)
		 {
			 getword();
			 if(sym==29)
			 {
				 getword();
				 typeil();
				 if(sym==32) getword();
				 else error();
			 }
			 else error();
		 }
		 else error();
	 }
	 else return 0;
}
int procsuff()
{
	if(sym==6)
	{
		procedh();
		block();
		if(sym==28) 
		{
			getword();
			procsuff();
		}
		else error();
	}
	else return 0;
}
int sentence()
{
	if(sym==34) assipro();
	else if(sym==7) ifsent();
	else if(sym==9) whilsent();
	else if(sym==11) read();
	else if(sym==12) write();
	else if(sym==13) compsent();
	else return 0;
}
void assipro()
{
	if(sym==34)
	{
		getword();
		suffix();
	}
	else error();
}
int suffix()
{
	if(sym==29)
	{
		getword();
		if(sym==20)
		{
			getword();
			express();
		}
		else error();
	}
	else if(sym==31)
	{
		getword();
		express();
		if(sym==32) getword();
		else error();
	}
	else return 0;
}
void ifsent()
{
	if(sym==7) 
	{
		getword();
		conditio();
		if(sym==8)
		{
			getword();
			sentence();
		}
		else error();

	}
	else error();
}
void whilsent()
{
	if(sym==9)
	{
		getword();
		conditio();
		if(sym==10)
		{
			getword();
			sentence();
		}
		else error();
	}
	else error();
}
void read()
{
	if(sym==11) 
	{
		getword();
		if(sym==31)
		{
			getword();
			if(sym==34)
			{
				getword();
				idsuff();
				if(sym==32) getword();
				else error();
			}
			else error();
		}
		else error();
	}
	else error();
}
void write()
{
	if(sym==12) 
	{
		getword();
		if(sym==31)
		{
			getword();
			express();
			exprsuff();
			if(sym==32) getword();
			else error();
		}
		else error();
	}
	else error();
}
int exprsuff()
{
	if(sym==26)
	{
		getword();
		express();
		exprsuff();

	}
	else return 0;
}
void compsent()
{
	if(sym==13)
	{
		getword();
		sentence();
		sentsuff();
		if(sym==14) getword();
		else error();
	}
	else error();
}
int sentsuff()
{
	if(sym==28)
	{
		getword();
		sentence();
		sentsuff();
	}
	else return 0;
}
void conditio()
{
	if(sym==16||sym==17||sym==34||sym==33||sym==31)
	{
		express();
		respoper();
		express();
	}
	else if(sym==15)
	{
		getword();
		express();
	}
	else error();
}
void express()
{
	if(sym==16||sym==17)
	{
		getword();
		term();
		termsuff();
	}
	else if(sym==34||sym==33||sym==31)
	{
		term();
		termsuff();
	}
	else error();
}


int termsuff()
{
	if(sym==16||sym==17)
	{
		addoper();
		term();
		termsuff();
	}
	else return 0;
}
void term()
{
	if(sym==34||sym==33||sym==31)
	{
		factor();
		factsuff();
	}
	else error();
}
int factsuff()
{
	if(sym==18||sym==19)
	{
		muloper();
		factor();
		factsuff();
	}
	else return 0;
}
void factor()
{
	if(sym==34) getword();
	else if(sym==33) getword();
	else if(sym==31) 
	{
		getword();
		express();
		if(sym==32) getword();
		else error();
	}
	else error();
} 
void addoper()
{
	if(sym==16||sym==17) getword();
	else error();
}
void muloper()
{
	if(sym==18||sym==19) getword();
	else error();
}
int respoper()
{
	if(sym==20) getword();
	else if(sym==22) 
	{
		getword();
		if(sym==20) getword();
        else return 0;
	}
	else if(sym==24)
	{
		getword();
		if(sym==20) getword();
        else return 0;
	}
	else error();
}
/*====================================*/
void main()
{
	int len=cifa();
	cout<<"字符代碼為:"<<endl;
	for(int i=0;i<len;i++)
	{
		cout<<code[i]<<"  ";
		if((i+1)%10==0) cout<<endl;
	}
	cout<<endl;
	program();
	if(flag==1) cout<<"語法分析正確"<<endl;
	else cout<<"程序錯(cuò)誤"<<endl;
}





















	






?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號(hào) Ctrl + =
減小字號(hào) Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
欧美国产激情二区三区 | 国内精品在线播放| 中文字幕精品在线不卡| 欧美肥妇毛茸茸| 99精品欧美一区二区三区小说| 免费欧美在线视频| 一区二区三区久久| 欧美国产精品中文字幕| 日韩一区二区精品在线观看| 97精品超碰一区二区三区| 久久国内精品视频| 亚洲成在人线免费| 最新不卡av在线| 久久久综合网站| 制服丝袜国产精品| 在线免费一区三区| 成人av午夜电影| 国产美女一区二区三区| 老司机精品视频一区二区三区| 亚洲综合色噜噜狠狠| 中文字幕免费在线观看视频一区| 日韩欧美中文字幕公布| 欧美区视频在线观看| 91蝌蚪国产九色| 成人综合在线观看| 国产成人精品一区二| 久久99精品视频| 日韩av午夜在线观看| 视频一区二区三区在线| 亚洲自拍偷拍av| 亚洲一区二区三区四区的| 亚洲精品国产a久久久久久| 日韩毛片视频在线看| 国产精品国产三级国产普通话蜜臀 | 亚洲综合激情网| 中文字幕在线不卡国产视频| 国产欧美在线观看一区| 国产婷婷一区二区| 精品国产91洋老外米糕| 久久亚洲综合色一区二区三区| 26uuu国产电影一区二区| 欧美不卡一区二区三区| 精品日韩av一区二区| 精品美女一区二区三区| 日韩一区二区视频在线观看| 欧美日韩一区二区三区在线看| 欧美日韩在线三区| 337p亚洲精品色噜噜| 91精品国产全国免费观看 | 欧美日韩综合不卡| 欧美色视频一区| 69av一区二区三区| 日韩一区二区麻豆国产| 久久久另类综合| 国产人伦精品一区二区| 久久久久综合网| 中文一区二区完整视频在线观看| 中文字幕欧美激情一区| 亚洲精选一二三| 日韩电影在线免费看| 国产中文一区二区三区| 成人高清在线视频| 91激情在线视频| 91精选在线观看| 久久久99精品久久| 亚洲欧洲综合另类在线| 亚洲福利视频三区| 精品一区二区综合| 成人免费视频国产在线观看| 91福利资源站| 日韩免费视频一区| 国产精品乱码久久久久久| 亚洲综合在线第一页| 激情久久五月天| av亚洲产国偷v产偷v自拍| 欧美美女bb生活片| 久久夜色精品国产欧美乱极品| 亚洲欧洲韩国日本视频| 日韩高清一级片| 国产成人精品综合在线观看| 欧美综合色免费| 精品1区2区在线观看| 亚洲另类在线视频| 蜜臀av一区二区| 99久久精品国产毛片| 日韩欧美成人一区二区| 最新高清无码专区| 六月丁香婷婷色狠狠久久| aaa亚洲精品| 欧美一区二区成人6969| 中文子幕无线码一区tr| 秋霞午夜av一区二区三区| eeuss影院一区二区三区| 91精品国产一区二区三区香蕉 | 免费看欧美美女黄的网站| 成人综合婷婷国产精品久久蜜臀| 欧美日韩国产精品成人| 综合欧美一区二区三区| 紧缚奴在线一区二区三区| 欧美在线|欧美| 国产精品黄色在线观看| 激情综合色播激情啊| 欧美日韩精品一区视频| 亚洲人精品一区| 国产成人自拍网| 欧美成人性战久久| 亚洲成人精品一区二区| av一本久道久久综合久久鬼色| 欧美电影精品一区二区| 亚洲成人一区二区在线观看| voyeur盗摄精品| 国产清纯白嫩初高生在线观看91| 奇米色一区二区三区四区| 欧美色老头old∨ideo| 亚洲天堂久久久久久久| 粉嫩绯色av一区二区在线观看| 777午夜精品免费视频| 亚洲在线视频网站| 色综合久久天天综合网| 中文字幕制服丝袜一区二区三区 | 国产91在线观看| 精品国产亚洲在线| 蜜桃av一区二区在线观看| 欧美高清视频一二三区 | 日韩欧美一区在线| 五月婷婷久久丁香| 欧美日韩免费视频| 亚洲福利一区二区三区| 欧美日韩一区三区四区| 亚洲午夜久久久久久久久电影院 | 欧美精品1区2区| 亚洲成va人在线观看| 91国偷自产一区二区使用方法| 亚洲欧洲无码一区二区三区| 成人av在线资源网| 国产精品美女久久久久久久久久久| 国产成人精品免费一区二区| 久久久精品tv| 国产成人亚洲综合a∨婷婷图片| 精品成人a区在线观看| 国产在线视频不卡二| 久久久精品tv| 成人免费va视频| 国产精品久久久久久久裸模 | 成人a免费在线看| 国产精品国产精品国产专区不片| 成人av免费在线| 亚洲欧美色综合| 欧美性猛交xxxx黑人交| 亚洲成人av在线电影| 4438成人网| 久久aⅴ国产欧美74aaa| 久久综合国产精品| 成人午夜看片网址| 亚洲欧洲国产专区| 在线观看视频91| 日韩和的一区二区| 337p日本欧洲亚洲大胆精品| 成人免费毛片高清视频| 伊人色综合久久天天人手人婷| 欧美日韩国产天堂| 美女视频网站久久| 亚洲国产高清在线| 在线视频观看一区| 久久国产乱子精品免费女| 久久久精品日韩欧美| av不卡在线观看| 亚洲小少妇裸体bbw| 精品理论电影在线观看 | 成人av网站免费观看| 一区二区三区成人在线视频| 91麻豆精品国产91久久久使用方法| 精品一区二区在线免费观看| 国产精品无人区| 欧美日韩在线播放| 国产成人亚洲综合色影视| 一区二区三区四区在线| 日韩欧美成人激情| 97se狠狠狠综合亚洲狠狠| 日韩黄色免费网站| 中文字幕欧美区| 欧美日韩aaa| 福利一区在线观看| 图片区小说区区亚洲影院| 国产亚洲一区二区三区| 欧美综合一区二区| 国产精品亚洲第一| 婷婷成人激情在线网| 中文字幕免费在线观看视频一区| 欧美日韩激情一区二区| 国产成人精品网址| 青青草成人在线观看| 亚洲精品欧美专区| 久久久精品黄色| 欧美一区二区三区婷婷月色| 99精品视频在线免费观看| 欧美亚洲一区二区在线| 成人一区在线观看| 美女看a上一区| 亚洲精品国产品国语在线app|