⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 parser.c

📁 将简单中缀算术表达式变换成: (1)后缀形式 (2)生成书上描述的抽象堆栈机的代码 (3)对常量算术表达式
💻 C
字号:
#include "global.h"
int lookahead;
parse()
{
	int t;
	
	lookahead = lexan();
	
	while (lookahead != DONE)
	{
		expr();
		if(flag==0)  //欲进行求值操作
		{
			if(wflag!=1) //不含标志符的表达式
				
				fprintf(fp2,"%d",pop());
			fprintf(fp2,"\n");
			
		}
		else       
			fprintf(fp2,"\n");
		initstack();
		wflag=0;
	}
}

expr()
{
	int t;
	term();
	while(1)
		switch (lookahead)
	{
		case'+':case '-':
			t=lookahead;
			match(lookahead);
			term();
			emit(t,NONE);
			continue;
		default:
			return;
	}
}

term()
{
	int t;
	factor();
	while(1)
		switch (lookahead)
	{
		case '*':case '/':case DIV: case MOD:
			t=lookahead;
			match(lookahead);
			factor();
			emit(t,NONE);
			continue;
		default:
			return;
	}
}

factor()
{
	switch(lookahead)
	{
	case'(':
		match('(');expr();match(')');break;
	case NUM:
		emit(NUM,tokenval);
		match(NUM);
		break;
	case ID:
		emit(ID,tokenval);match(ID);break;
	default:
		error("syntax error");
	}
}

match(t)
int t;
{
	if(lookahead== t)
	{
		lookahead = lexan();
	}
	else error("syntax error");
}

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -