编译原理 《递归下降语法分析程序设计》

本文介绍了如何构建一个用于解析算术表达式的递归下降分析程序,遵循LL(1)文法。实验任务包括读取算术表达式,通过switch case语句实现错误处理和同步分析。程序能够处理标识符和基本运算,并在遇到特定符号时给出不同的执行反馈。示例展示了如何处理表达式,并提供了源代码供参考。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

实验任务

完成以下描述算术表达式的LL(1)文法的递归下降分析程序构建

G[E]:

        E→TE′

        E′→+TE′|ε

        T→FT′

        T′→*FT′|ε

               F→(E)|i

     说明:终结符号i为用户定义的简单变量,即标识符的定义。

要求具有如下功能:

  • 从文件读入算术表达式/或者从终端输入
  • 总控函数分析算术表达式;
  • 根据分析结果正误,分别给出不同信息


我用的switch case 语句来构建的编译器 通过对表达式的预测分析表  来实现正确情况,同步情况以及错误情况的分析,能够找出错误并继续执行。

执行方式:表达式+$结尾
若最后的符号是)则会运行出结果后退出,其他则继续执行。


例子:i+i$,i+i*(i+i)

 

源代码如下:

#include <stdio.h>
#include <stdlib.h>
#include <string.h>

char str[20];
int len;
int index;
int error;
int right;
int left;


void E();  // E->TX;
void E_prime();  // X->+TX | e
void T();  // T->FY
void T_prime();  // Y->*FY | e
void F();  // F->(E) | i
void display();

int main() {

	while(1) {
		len=0;
		index = 0;
		error = 0;
		right = 0;
		left = 0;

		/*----------- 输入表达式 ---------------*/
		printf("请输入算数表达式:");
		scanf("%s", str);
		len = strlen(str);
		E();
		if (str[index] == '$'&& error == 0) {
			if(left==right) {
				printf("正确语句!\n");
			}
			if(left<right) {
				printf("错误语句!缺少左括号!\n");
			}
			if(left>right) {
				printf("错误语句!缺少右括号!\n");
			}
		} else {
			if(left<right) {
				printf("错误语句!缺少左括号!\n");
			}
			i
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值