news 2026/6/15 20:05:27

编译原理大作业:3-非递归预测分析

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
编译原理大作业:3-非递归预测分析

1.实验目的

设计一个非递归预测分析器,实现对表达式语言的分析,理解自上而下语法分析方法的基本思想,掌握设计非递归预测分析器的基本方法。

2.实验要求

建立文法及其LL(1)分析表表示的数据结构,设计并实现相应的预测分析器,对源程序经词法分析后生成的二元式代码流进行预测分析,如果输入串是文法定义的句子则输出“是”, 否则输出“否”。

3.实验内容

(1)文法描述及其 LL(1)分析表

表达式语言(XL)的语法规则如下:

  1. 1.程序 → 表达式;
  2. 2. |表达式;程序
  3. 3. 表达式→ 表达式 + 项
  4. 4. |项
  5. 5. 项 → 项 * 因式
  6. 6. |因式
  7. 7. 因式 → num_or_id
  8. 8. | (表达式)

将该语言的文法转换为如下的LL(1)文法:

  1. 1 prgm → expr;prgm ’ 8 term → factor
  2. term ’
  3. 2 prgm ’ → prgm 9 term ’ → *factor
  4. term ’
  5. 3 prgm ’ → ε 10 term ’ → ε
  6. 4 expr → term expr ’ 11 factor → (expr)
  7. 5 expr → ε 12 f actor → num
  8. 6 expr ’ → +term expr ’ 13 system_goal → prgm
  9. 7 expr ’ → ε

该LL(1)文法的LL(1)分析表如下:

对文法中每个文法符号指定一个常数值,符号编码表如下:

(2)文法及其LL(1)分析表的数据结构

文法的产生式可用数组Yy_pushtab[]存放。数组的第一个下标是产生式号,第一个产生式的序号为0;每列按逆序存放该产生式右部各符号的常数值,并以0结束。对于该表达式语言XL的LL(1)分析表,可用数组Yy_d[]存放。第一个下标是非终结符数值,第二个下标是终结符数值,数组元素的值为:0(表示接受),1(表示产生式号),-1(表示语法错)。

数组Yy_pushtab[]的具体内容及表示如下:

数组Yy_d[]的具体内容及表示如下:

(3)预测分析器总控程序结构

预测分析器总控程序使用上面的两个表Yy_pushtab、Yy_d和一个分析栈(元素类型为int),其结构如下:

初始化;/* 把开始符号的常数值压入分析栈,输入指向第一个输入符号 */ while(分析栈非空) { if(栈顶常数表示一个终结符) if(该常数与输入符号的常数不等) 报语法错; else { 把一个数从栈顶弹出; advance 读下一输入符; } else { /* 栈顶的常数表示一个非终结符 */ what_to_do=Yy_d[栈顶常数][当前输入符号的常数]; if(what_to_do==-1) 报语法错; else { 把栈顶元素弹出栈; 把Yy_pushtab[what_to_do]中列出的全部常数压入分析栈; } } }

请实现该程序。在程序中添加输出栈内容的功能,以便和手工模拟分析过程作比较。

(4)用预测分析器和手工模拟两种方式对文法的句子1+2;进行分析。综合分析过程可用下表表示。

(5)请考虑如何设计并实现 LL(1)分析表的自动生成程序。

4.实验结果

(1)LL(1)文法

(2)预测分析表

(3)手工模拟结果

截图显示,输入串为1+2;,经过预测分析后判断是文法定义的句子,说明实验成功。

5.实验源码

点击下方链接下载实验源码资源:

编译原理大作业:3-非递归预测分析-实验源码资源-CSDN下载

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/6/14 20:58:44

48、Unix知识综合解析

Unix知识综合解析 1. 重要Unix命令 在Unix系统中,有许多用于进程创建、删除和管理的命令,以及一些杂项程序命令,它们在系统操作和管理中发挥着重要作用。 进程相关命令 - at :在指定时间执行作业,作业仅执行一次。 - batch :在系统负载不过高时执行作业。 - …

作者头像 李华
网站建设 2026/6/15 5:19:43

VaR模型总失效?你可能忽略了这3个R语言关键检验步骤,

第一章:VaR模型总失效?重新审视R语言下的风险度量在金融危机频发的背景下,VaR(Value at Risk)模型频繁被质疑“失效”。然而,问题往往不在于模型本身,而在于其应用方式与假设前提的误用。借助R语…

作者头像 李华
网站建设 2026/6/15 12:16:49

【大模型数据标注】核心技术与优秀开源框架

文章目录目录引言一、大模型数据标注核心技术1. 有监督标注技术(基础核心)2. RLHF标注技术(对齐人类偏好)3. 自监督与半监督标注技术(降本增效)4. 自动化与模型辅助标注技术(效率核心&#xff0…

作者头像 李华
网站建设 2026/6/15 14:30:13

资料: 软件滤波算法、数字滤波常用的算法, AD采集,数据采集等经常会遇到由于干扰、电路误差、...

资料: 软件滤波算法、数字滤波常用的算法, AD采集,数据采集等经常会遇到由于干扰、电路误差、精度、抖动等带来的误差,这些误差往往影响我们单位计算或控制,在平常的设计中,我们会加各种软件滤波来让数据变得平滑&…

作者头像 李华
网站建设 2026/6/15 13:56:20

紧急修复漏洞来不及?用这1种方法实现PHP组件秒级更新

第一章:低代码 PHP 组件的更新机制在现代Web开发中,低代码平台通过可视化界面和模块化设计显著提升了PHP应用的开发效率。其中,组件的更新机制是保障系统稳定性和功能迭代的关键环节。低代码PHP组件通常以独立模块形式存在,其更新…

作者头像 李华
网站建设 2026/6/15 12:34:07

从农场到云端的安全链路,PHP如何扛起设备认证最后一道关卡?

第一章:从农场到云端的安全链路,PHP如何扛起设备认证最后一道关卡在现代农业物联网系统中,传感器设备从田间采集数据后,需经由安全链路上传至云端平台。而在这条链路的末端,PHP作为后端服务的核心语言之一,…

作者头像 李华