news 2026/4/23 17:45:59

HNU 编译系统 作业3

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
HNU 编译系统 作业3

题目1

题干

对以上上下文无关文法与对应的串:

  • 给出这个串的一个最左推导
  • 给出这个串的一个最右推导
  • 给出这个串的一棵语法分析树

(1)对于文法S -> + S S | * S S | a和输入字符串+ * a a a
最左推导:

S -> + S S -> + * S S S -> + * a S S -> + * a a S -> + * a a a

最右推导:

S -> + S S -> + S a -> + * S S a -> + * S a a -> + * a a a

语法分析树:

(2)对于文法S -> S ( S ) S | ε和输入字符串( ( ) ( ) )
最左推导:

S -> S ( S ) S -> ε ( S ) S -> ( S ) S -> ( S ( S ) S ) S -> ( ε ( S ) S ) S -> ( ( S ) S ) S -> ( ( ε ) S ) S -> ( ( ) S ) S -> ( ( ) S ( S ) S ) S -> ( ( ) ε ( S ) S ) S -> ( ( ) ( S ) S ) S -> ( ( ) ( ε ) S ) S -> ( ( ) ( ) S ) S -> ( ( ) ( ) ε ) S -> ( ( ) ( ) ) S -> ( ( ) ( ) ) ε -> ( ( ) ( ) )

最右推导:

S -> S ( S ) S -> S ( S ) ε -> S ( S ) -> S ( S ( S ) S ) -> S ( S ( S ) ε ) -> S ( S ( S ) ) -> S ( S ( ε ) ) -> S ( S ( ) ) -> S ( S ( S ) S ( ) ) -> S ( S ( S ) ε ( ) ) -> S ( S ( S ) ( ) ) -> S ( S ( ε ) ( ) ) -> S ( S ( ) ( ) ) -> S ( ε ( ) ( ) ) -> S ( ( ) ( ) ) -> ε ( ( ) ( ) ) -> ( ( ) ( ) )

语法分析树:

题目2

题干

为题目1中的每一个文法设计一个预测分析器。你可能先要对文法进行提取左公因子或消除左递归的操作。

对于文法S -> + S S | * S S | a

parse_S() { // S -> + S S | * S S | a token = nextToken(); switch(token) if (token == "+") { move token; parse_S(); parse_S(); } if (token == "*") { move token; parse_S(); parse_S(); } if (token == "a") { move token; } else error("..."); }

对于文法S -> S ( S ) S | ε,先消除左递归得到新文法:

S' -> ( S ) S S' | ε S -> S'

再写递归下降的预测分析器:

parse_S() { // S -> S' token = nextToken(); switch(token) if (token == "(") { parse_S_prime(); } else if (token in [$, (, )]) { // ε } else error("..."); } parse_S_prime() { // S' -> ( S ) S S' | ε token = nextToken(); switch(token) if (token == "(") { move token; parse_S(); move token; parse_S(); parse_S_prime(); } else if (token in [$, (, )]) { // ε } else error("..."); }

题目3

题干

计算题目1中的各个文法的FIRST和FOLLOW集合。你可能先要对文法进行提取左公因子或消除左递归的操作。

(1)对于文法S -> + S S | * S S | a
该文法没有左公因子和左递归。

(2)对于文法S -> S ( S ) S | ε
对该文法消除左递归后得到新文法:

S' -> ( S ) S S' | ε S -> S'

题目4

判断题目1中的文法是否为LL(1)文法,如果是则填写其LL(1)语法分析表。

(1)对于文法S -> + S S | * S S | a
该文法是LL(1)文法,语法分析表如下:

(2)对于文法S -> S ( S ) S | ε
该文法不是LL(1)文法,因为存在左递归。

题目5

为下面的语言设计文法。
(1)所有由0和1组成的并且每个0之后至少跟着一个1的串的集合。
(2)所有由0和1组成的回文(palindrome)的集合,也就是从前面和从后面读结果都相同的串的集合。

(1)

S -> 0 1 S | 1 S | ε

(2)

S -> 0 S 0 | 1 S 1 | 0 | 1 | ε

题目7

(1)对于以上两个文法,分别画出其LR(0)项集的状态转换图(即DFA)。
(2)判断它们是否为LR(0)文法,是否为SLR(1)文法,给出理由。
(3)如果是LR(0)文法或SLR(1)文法,填出其LR语法分析表。

(1)对于文法S -> S S + | S S * | a,得到增广文法

0 : S' -> S $ 1 : S -> S S + 2 : | S S * 3 : | a

对于文法S -> a S a | a a,得到增广文法

0 : S' -> S $ 1 : S -> a S a 2 : | a a

(2)对于文法S -> S S + | S S * | a
LR(0)分析表:

是LR(0)文法,因为LR(0)分析表中无冲突。
SLR(1)分析表:

是SLR(1)文法,因为SLR(1)分析表中无冲突。
对于文法S -> a S a | a a
LR(0)分析表:

不是LR(0)文法,因为LR(0)分析表中,状态4输入符号为a时有移进-规约冲突。
SLR(1)分析表:

不是SLR(1)文法,因为SLR(1)分析表中,状态4输入符号为a时仍有移进-规约冲突。
(3)见(2)。

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

python pandas操作excel

Python的Pandas库是处理Excel文件的强大工具,它提供了简洁高效的接口来读取、处理和分析表格数据。下面将详细介绍使用Pandas操作Excel的核心方法、常见场景及进阶技巧。一、安装与环境准备使用Pandas处理Excel文件前,需要安装Pandas及相应的引擎库&…

作者头像 李华
网站建设 2026/4/23 11:47:39

大雪深埋强化课划重点|保号性专题

🗺️ 专题框架与考点梳理 系统地梳理了微积分中的核心考点,并突出了保号性在其中的地位: 保号性是极限理论中一个核心且非常实用的性质,当“看到极限严格大于或严格小于”某个值时,就应该立刻联想到它。 流程图&…

作者头像 李华
网站建设 2026/4/23 11:46:14

vue基于Springboot框架的个人健康运动健身饮食人体血糖监测系统

目录已开发项目效果实现截图开发技术系统开发工具:核心代码参考示例1.建立用户稀疏矩阵,用于用户相似度计算【相似度矩阵】2.计算目标用户与其他用户的相似度系统测试总结源码文档获取/同行可拿货,招校园代理 :文章底部获取博主联系方式&…

作者头像 李华
网站建设 2026/4/23 11:45:14

湖南网安基地:湖南地区口碑最好的网络安全培训机构深度测评

一、为什么选择湖南网安基地?"零基础转行网络安全,真的能拿到高薪吗?"这是许多想进入网络安全领域的人最关心的问题。答案是:能,但前提是选对平台。湖南网安基地作为国家网络安全人才培养基地,学…

作者头像 李华
网站建设 2026/4/23 11:46:30

网络安全渗透测试工具:新手必看指南

一、渗透测试工具分类渗透测试工具按照功能可以分为六大类,覆盖从信息收集到漏洞利用的全流程测试需求。1. 信息收集工具Nmap(Network Mapper)是网络扫描的行业标准工具,用于发现网络中的设备、识别开放端口、探测服务版本和操作系…

作者头像 李华
网站建设 2026/4/23 17:34:35

Newsletter内容规划:每月一期高质量通讯

LobeChat:构建专属AI通信门户的技术实践 在企业纷纷拥抱大模型的今天,一个现实问题逐渐浮现:我们拥有了强大的语言模型,却依然缺乏真正好用、安全且可控的交互入口。开发者面对的是API密钥满天飞、界面割裂、数据外泄风险高企的局…

作者头像 李华