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

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

?? 實驗3.cpp

?? 中間代碼生成 掌握語學制導下的中間代碼生成技術
?? CPP
?? 第 1 頁 / 共 2 頁
字號:
//實驗三  中間代碼生成

#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <ctype.h>
#include <malloc.h>
#include <conio.h>
#include <fstream.h>
#include <iostream.h>
#include <iomanip.h>

/*************************下面是與詞法分析相關的一些全局變量與函數的聲明*************************/

#define NULL 0
FILE *fp;//源文件的指針
FILE *out,*in;//輸出二元式表文件的指針,輸出預處理文件的指針
char ch,str;
char filename[50];//源文件路徑及名稱
char *keyword[4]={"IF","THEN","ELSE","GOTO"};//關鍵字
char *operatornum[4]={"+","-","*","/"};//運算符
char *comparison[6]={">","<",">=","<=","=","<>"};//關系符
char *interpunction[4]={",",":","(",")"};//界符
bool search(char searchstr[],int wordtype);//查找單詞種別函數
char letterprocess(char ch);//字母處理函數
char numberprocess(char ch);//數字處理函數
char otherprocess(char ch);//其它字符處理函數
char process(char ch);//處理空格函數
void pro_process(char *buf);//預處理函數
void Scaner();//詞法掃描函數

/*************************下面是與語法分析相關的一些全局變量與函數的聲明*************************/

#define N 100
FILE *ff;//讀取預處理文件的指針
//定義符號棧的大小與輸入字符串的大小以及算術表達式字符串的大小
char stack[N],strings[N],oldstrings[N];
char a;
int top=-1,k=0,step=1,n=0,No[N],id=1;
//二維數組定義字符之間的優先關系(1表示>,-1表示<,0表示=,-2表示錯誤)
int M[N][N]={{1,1,-1,-1,-1,1,-1,1},{1,1,-1,-1,-1,1,-1,1},{1,1,1,1,-1,1,-1,1},{1,1,1,1,-1,1,-1,1},
             {-1,-1,-1,-1,-1,0,-1,-2},{1,1,1,1,-2,1,-2,1},{1,1,1,1,-2,1,-2,1},{-1,-1,-1,-1,-1,-2,-1,0}};        
char *word[6]={"N+N","N-N","N*N","N/N",")N(","i"};//可歸約字符串
void print(int t,int m);//打印算符優先語法分析程序的分析結果
void push(char ch);//入棧函數
char pop();//出棧函數
int ch_di(char ch);//定義字符標識
int IsVT(char ch);//判斷是否為終結符
int readvt(char *a);//讀入字符
int big(int t,char a);//判斷t優先級是否高于a
int less(int t,char a);//判斷t優先級是否低于a
int equal(int t,char a);//判斷t優先級是否等于a
void error1(int t);//錯誤分析函數
void prior_analysis();//自下而上分析
void suanfu();//算符優先語法主函數

/*************************下面是與語義分析相關的一些全局變量與函數的聲明*************************/

#define MAXLENGTH 63
union WORDCONTENT{//存放單詞內容的聯合
	char T1[MAXLENGTH];
	int T2;
	char T3;
};
typedef struct WORD{//單詞二元組
	char syn;
	union WORDCONTENT value;
}WORD;
typedef struct QUAD{//四元式的結構
	char op[MAXLENGTH];
	char argv1[MAXLENGTH];
	char argv2[MAXLENGTH];
	char result[MAXLENGTH];
}QUATERNION;
QUATERNION *pQuad;//存放四元式的數組
int nSuffix,nNXQ,ntc,nfc,tag1;//臨時變量的編號
WORD uWord;//掃描得到的單詞
FILE *fw;//輸出四元式表文件的指針
void error(char *strError);//輸出掃描發現的錯誤
int Match(char syn,char *strError);//匹配當前識別出的單詞
void gen(char *op,char *argv1,char *argv2,char *result);//生成一個四元式
void PrintQuaternion();//打印四元式數組
char *Newtemp();//產生一個臨時變量
int merge(int p1,int p2);//合并p1和p2
void backpatch(int p,int t);//將t回填到以p為首的四元式中
char *Expression();//分析算術表達式函數
char *Term();//分析項函數
char *Factor();//分析因子函數
void Condition(int *etc,int *efc);//分析布爾表達式函數
void Statement(int nChain);//語句分析函數
void Statement_Sequence(int nChain);//語句串分析函數
void Parse();//分析生成中間代碼

/***********************************以下是詞法分析部分***********************************/

//////////////////////////////////////////////////////////////////////////////////////////

bool search(char searchstr[],int wordtype)//查找單詞種別函數
{
    int i;
    switch(wordtype)
	{
        case 1: for(i=0;i<=3;i++)//識別關鍵字
				{
                    if(strcmp(keyword[i],searchstr)==0)
                        return true;     
				}
        case 2: for(i=0;i<=3;i++)//識別運算符
				{
                    if(strcmp(operatornum[i],searchstr)==0)
                        return true;
				}  
        case 3: for(i=0;i<=5;i++)//識別關系符
				{
                    if(strcmp(comparison[i],searchstr)==0)
                        return true;
				}
        case 4: for(i=0;i<=3;i++)//識別界符
				{
                    if(strcmp(interpunction[i],searchstr)==0)
                        return true;
				}
	}
    return false;
}

//////////////////////////////////////////////////////////////////////////////////////////

char letterprocess(char ch)//字母處理函數
{
    int i=-1,j=-1,temp1;
    char letter[20],temp[10];
    while(isalnum(ch)!=0)
	{
        letter[++i]=ch;
        ch=fgetc(fp);
	}
    letter[i+1]='\0';
    if(search(letter,1))//輸出關鍵字二元式
	{
        printf("(K,%5s)\n",letter);
		fprintf(out,"(K,%s)\n",letter);
		if(strcmp(letter,"GOTO")==0)//輸出標號二元式
		{
			ch=fgetc(fp);
            while(isdigit(ch)!=0)
			{
                temp[++j]=ch;
                ch=fgetc(fp);
			}
			temp[j+1]='\0';
			printf("(L,%5s)\n",temp);
		    fprintf(out,"(L,%s)\n",temp);
			temp1=atoi(temp);
	        uWord.syn='L';
	        uWord.value.T2=temp1;
		}
		uWord.syn='K';
		strcpy(uWord.value.T1,letter);
	}
    else//輸出標識符二元式
	{
        printf("(I,%5s)\n",letter);
		fprintf(out,"(I,%s)\n",letter);
		uWord.syn='I';
		strcpy(uWord.value.T1,letter);
	}
    return ch;
}

//////////////////////////////////////////////////////////////////////////////////////////

char numberprocess(char ch)//數字處理函數
{
    int i=-1,temp;
    char num[20];
    while(isdigit(ch)!=0)
	{
        num[++i]=ch;
        ch=fgetc(fp);
	}
    if(isalpha(ch)!=0)
	{
        while(isalpha(ch)!=0)
		{
            num[++i]=ch;
            ch=fgetc(fp);
		}
        num[i+1]='\0';
        printf("非法標識符: %s\n",num);
		fprintf(out,"非法標識符: %s\n",num);
	}
	if(ch==':')//輸出標號二元式
	{
        num[i+1]='\0';
        printf("(L,%5s)\n",num);
		fprintf(out,"(L,%s)\n",num);
		temp=atoi(num);
	    uWord.syn='L';
	    uWord.value.T2=temp;
	}
	else//輸出常數二元式
	{
        num[i+1]='\0';
        printf("(C,%5s)\n",num); 
		fprintf(out,"(C,%s)\n",num);
	    temp=atoi(num);
	    uWord.syn='C';
	    uWord.value.T2=temp;
	}
    return ch;
}

//////////////////////////////////////////////////////////////////////////////////////////

char otherprocess(char ch)//其它字符處理函數
{
    int i=-1;
    char other[10];
	if(ch=='(')
	{
		other[++i]=ch;
		ch=fgetc(fp);
	}
    while(isalnum(ch)==0&&ch!=' '&&ch!='('&&ch!=')')
	{
        other[++i]=ch;
        ch=fgetc(fp);
	}
	if(ch==')')
	{
		other[++i]=ch;
		ch=fgetc(fp);
	}
    other[i+1]='\0';
    if(search(other,4))//輸出界符二元式
	{
        printf("(P,%5s)\n",other);
		fprintf(out,"(P,%s)\n",other);
		uWord.syn='P';
		uWord.value.T3=other[0];
	}
    else if(search(other,2)||search(other,3))//輸出運算符二元式
	{
        printf("(O,%5s)\n",other);
		fprintf(out,"(O,%s)\n",other);
		uWord.syn='O';
		strcpy(uWord.value.T1,other);
	}
    else
	{
        printf("非法字符: %s\n",other);
		fprintf(out,"非法字符: %s\n",other);
	}
    return ch;
}

//////////////////////////////////////////////////////////////////////////////////////////

char process(char ch)//處理空格函數
{
    while(ch==' ')
        ch=fgetc(fp);
    return ch;
}

//////////////////////////////////////////////////////////////////////////////////////////

void pro_process(char *buf)//預處理函數
{
    ifstream cinf(filename,ios::in);
	int i=0;//計數器
	char old_ch='\0',cur_ch;//前一個字符,當前字符
	bool comment=false;//false表示當前字符未處于注釋中
	while(cinf.read(&cur_ch,sizeof(char)))//從文件讀一個字符
	{
		switch(comment)
		{
	        case false:
			    if(old_ch=='/'&&cur_ch=='*')//進入注釋
				{
				    i--;//去除已存入掃描緩沖區的字符'/'
				    comment=true;
				}
			    else
				{
				    if(old_ch=='\\'&&cur_ch=='\n')//發現續行
					    i--;//去除已存入掃描緩沖區的字符'\'
				    else
					{
					    if(cur_ch=='\t'||cur_ch=='\r'||cur_ch=='\n')//空格取代Tab換行
						    cur_ch=' ';
						if(old_ch==' '&&cur_ch==' ')//一個空格取代多個空格
						    i--;//去除已存入掃描緩沖區的字符' '
					    buf[i++]=cur_ch;
					}
				}
			    break;
		    case true:
			    if(old_ch=='*'&&cur_ch=='/')//離開注釋
				    comment=false;
		}
		old_ch=cur_ch;//保留前一個字符
	}
	buf[i++]='#';//在源程序尾部添加字符'#'
}

//////////////////////////////////////////////////////////////////////////////////////////

void Scaner()//詞法掃描函數
{
	if(str!='#')
	{
        str=process(str);//空格處理
        if(isalpha(str)!=0)
            str=letterprocess(str);//字母處理
        else
		{
            if(isdigit(str)!=0)
                str=numberprocess(str);//數字處理
            else
                str=otherprocess(str);//其它字符處理
		} 
	}
	else
		strcpy(uWord.value.T1,"end");
}

/***********************************以下是語法分析部分***********************************/

//////////////////////////////////////////////////////////////////////////////////////////

void print(int t,int m)//打印算符優先語法分析程序的分析結果
{
    cout<<"\n "<<step++<<setw(10);//輸出步驟號
    cout<<stack<<setw(10);//輸出符號棧	
    if(m==1)//輸出優先關系
        cout<<">"<<setw(8);
    else if(m==0)
        cout<<"="<<setw(8);
    else
        cout<<"<"<<setw(8);
    cout<<a<<setw(10);//輸出當前分析符
    cout<<&strings[k]<<setw(10);//輸出剩余輸入串
    if(t)//輸出動作
	{
        cout<<"歸約"<<setw(8);
        No[n++]=step-1;
	}
    else
        cout<<"移進"<<setw(8);
}

//////////////////////////////////////////////////////////////////////////////////////////

void push(char ch)//入棧函數
{
    stack[++top]=ch;
}

//////////////////////////////////////////////////////////////////////////////////////////

char pop()//出棧函數
{
	char a;
	a=stack[top--];
	stack[top+1]='\0';
    return a;
}

//////////////////////////////////////////////////////////////////////////////////////////

int ch_di(char ch)//定義字符標識
{
    switch(ch)
	{
        case'+':
            return 1;
        case'-':
            return 2;
        case'*':
            return 3;
        case'/':
            return 4;
        case'(':
            return 5;
        case')':
            return 6;
        case'i':
            return 7;
		case'#':
            return 8;
        default:
            return 0;
	}
}

//////////////////////////////////////////////////////////////////////////////////////////

int IsVT(char ch)//判斷是否為終結符
{
    if(ch=='N')
        return 0;
    else
        return 1;
}

//////////////////////////////////////////////////////////////////////////////////////////

int readvt(char *a)//讀入字符
{
    if(IsVT(strings[k]))
	{
        (*a)=strings[k];
        k++;
        return 1;
	}
    else
	{
        k++;
        return 0;
	}
}

//////////////////////////////////////////////////////////////////////////////////////////

int big(int t,char a)//判斷t優先級是否高于a
{
    if(M[ch_di(stack[t])-1][ch_di(a)-1]==1)
		return 1;
	else
		return 0;
}

//////////////////////////////////////////////////////////////////////////////////////////

int less(int t,char a)//判斷t優先級是否低于a
{
    if(M[ch_di(stack[t])-1][ch_di(a)-1]==-1)
		return 1;
	else
		return 0;
}

//////////////////////////////////////////////////////////////////////////////////////////

int equal(int t,char a)//判斷t優先級是否等于a
{
    if(M[ch_di(stack[t])-1][ch_di(a)-1]==0)
		return 1;
	else
		return 0;
}

//////////////////////////////////////////////////////////////////////////////////////////

void error1(int t)//錯誤分析函數
{
    if(ch_di(stack[t])==6||ch_di(stack[t])==7)
	{
        printf("\n錯誤e2:缺少運算符!");
	}
	else if(ch_di(stack[t])==5)
	{
		printf("\n錯誤e1:非法左括號!");
	}
	else 
        printf("\n錯誤e3:非法右括號!");
}

//////////////////////////////////////////////////////////////////////////////////////////

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
日韩精品一区二区三区老鸭窝| 视频一区欧美日韩| 在线精品国精品国产尤物884a| 欧美伦理影视网| 久久婷婷国产综合精品青草| 毛片av中文字幕一区二区| 国产视频视频一区| 国产激情一区二区三区桃花岛亚洲| 欧美日韩在线三级| 国产一区二区三区四区五区美女| 中文字幕中文在线不卡住| 欧美性大战久久久久久久蜜臀| 精品一区二区三区在线播放视频| 综合久久给合久久狠狠狠97色 | 91亚洲国产成人精品一区二三 | 91老司机福利 在线| 亚洲综合男人的天堂| 欧美电影免费观看高清完整版在线| 成人午夜伦理影院| 国产精品久久久久久一区二区三区 | 国产精品性做久久久久久| 中文子幕无线码一区tr| 欧美日韩一区视频| 一本久久a久久精品亚洲| 韩国av一区二区三区四区| 亚洲一区精品在线| 亚洲一区二区黄色| 成人欧美一区二区三区1314| 欧美区视频在线观看| 色婷婷激情综合| 狠狠色综合色综合网络| 亚洲国产精品视频| 亚洲欧美日韩一区| 夜色激情一区二区| 国产精品人人做人人爽人人添| 久久久久久黄色| 国产午夜精品一区二区| 国产欧美日韩不卡免费| 欧美激情艳妇裸体舞| 国产女人18毛片水真多成人如厕 | 国产成人日日夜夜| 成人h动漫精品| 欧美精品自拍偷拍动漫精品| 日韩一区二区精品葵司在线| 国产人成亚洲第一网站在线播放| 自拍偷拍欧美激情| 蓝色福利精品导航| 91蜜桃婷婷狠狠久久综合9色| 欧美日韩午夜影院| 中文子幕无线码一区tr| 日韩黄色在线观看| 不卡一卡二卡三乱码免费网站| 欧美亚洲禁片免费| 在线欧美日韩精品| 99久久久精品| 91精品黄色片免费大全| 亚洲精品日韩一| 狠狠久久亚洲欧美| 欧美美女喷水视频| 亚洲免费观看高清在线观看| 久久激五月天综合精品| 91精品办公室少妇高潮对白| 久久久久久久久久久久久夜| 亚洲国产日产av| 99久久er热在这里只有精品15| 日韩精品一区二区三区视频播放| 亚洲精品第1页| 在线日韩一区二区| 亚洲线精品一区二区三区八戒| 国产毛片一区二区| 久久婷婷色综合| 国模少妇一区二区三区| 精品久久99ma| 精品在线一区二区| 精品国产凹凸成av人网站| 青青青伊人色综合久久| 欧美网站大全在线观看| 石原莉奈一区二区三区在线观看| 欧美专区亚洲专区| 视频一区欧美日韩| 日韩精品一区二区三区四区| 国产一区二区中文字幕| 精品国产免费人成电影在线观看四季 | 九九九精品视频| 国产精品区一区二区三区| 成人一级片在线观看| 国产精品美女久久久久久2018 | av在线不卡网| 亚洲高清久久久| 精品国产一区二区精华| 国产福利不卡视频| 亚洲综合成人在线视频| 在线不卡中文字幕| 国产福利91精品一区二区三区| 国产精品乱人伦中文| 欧美日本一道本| 国产成人免费高清| 午夜视频一区二区三区| 精品国产一区二区三区四区四| 9人人澡人人爽人人精品| 午夜精品在线看| 久久久高清一区二区三区| 色天天综合久久久久综合片| 久久99久久久久| 亚洲自拍偷拍网站| 国产精品美女久久久久久久久久久 | 欧美一区二区在线视频| 色婷婷av久久久久久久| 国产精品视频九色porn| 欧美肥大bbwbbw高潮| 成人性生交大片免费看视频在线 | youjizz久久| 蜜臀av国产精品久久久久| 久久久另类综合| 国产成人精品在线看| 亚洲欧洲日韩在线| 久久婷婷成人综合色| 欧美日韩高清一区| 欧美疯狂做受xxxx富婆| 色欧美日韩亚洲| 91国偷自产一区二区三区观看 | 欧美国产日韩精品免费观看| 日韩一级完整毛片| 欧美一区二区三区播放老司机| 日本道色综合久久| 在线观看一区二区精品视频| 99久久综合精品| 日本韩国一区二区| 欧美中文字幕一区二区三区| 色噜噜夜夜夜综合网| av在线这里只有精品| 色综合中文字幕国产| 成人国产亚洲欧美成人综合网| 成人精品国产一区二区4080| 成人精品视频一区| 在线看日韩精品电影| 91精品国产91综合久久蜜臀| 日韩欧美久久一区| 国产精品女人毛片| 亚洲精品日日夜夜| 久久精品噜噜噜成人av农村| 国产盗摄视频一区二区三区| av不卡在线播放| 69精品人人人人| 久久久精品黄色| 一区二区三区在线视频播放| 天堂成人免费av电影一区| 麻豆极品一区二区三区| 丰满放荡岳乱妇91ww| 欧美日韩国产首页| 国产欧美综合在线| 亚欧色一区w666天堂| 亚洲成av人在线观看| 国产精品人成在线观看免费| 国产高清精品网站| 91黄色在线观看| 日韩欧美久久久| 亚洲大片在线观看| 北条麻妃一区二区三区| 日韩欧美一区二区视频| 亚洲激情成人在线| 国产成人精品一区二| 91精品国产日韩91久久久久久| 成人欧美一区二区三区白人| 美日韩一级片在线观看| 在线观看视频一区| 亚洲视频综合在线| 成人高清av在线| 久久精品亚洲国产奇米99| 日韩中文字幕麻豆| 欧美在线一区二区三区| 一区二区三区中文在线| 91免费看`日韩一区二区| 欧美韩国一区二区| 不卡一二三区首页| 亚洲视频在线一区| 欧美亚洲国产一区二区三区va| 国产精品久久久久影院亚瑟| 成人免费视频免费观看| 亚洲色图欧美在线| 91免费观看视频在线| 亚洲一区中文在线| 337p亚洲精品色噜噜噜| 久久精品久久精品| 久久精品在线免费观看| 成人久久久精品乱码一区二区三区| 国产色综合久久| 91黄色免费看| 久久精品国产一区二区三| 国产亚洲一区二区三区在线观看| 国产老女人精品毛片久久| ...av二区三区久久精品| 亚洲综合自拍偷拍| 从欧美一区二区三区| 专区另类欧美日韩| 51精品秘密在线观看| 国产成人8x视频一区二区| 中文字幕一区三区| 日韩欧美一二三四区| 懂色av一区二区三区蜜臀|