news 2026/6/16 15:52:22

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/6/16 11:24:41

Windows 查看本次开机时间

在Windows系统中,可以通过多种CMD命令来查看电脑的开机时间。以下是几种常用的方法:1. 使用 systeminfo 命令这是最常用且简单的方法。在命令提示符中执行此命令后,可以快速找到系统的启动时间。操作步骤:按下 Win R 键&#xff…

作者头像 李华
网站建设 2026/6/16 18:35:37

在北京,寻找能聊创业、聊生活、一起向上的同行者

在北京这座快节奏的城市里,你是否也常觉得:想聊创业思路时,身边少个能懂你野心的人;想解锁生活乐趣时,找不到合拍的同伴?其实好的同行者,或许只差一个相遇的契机。超哥做新媒体创业,…

作者头像 李华
网站建设 2026/6/16 23:32:41

vue基于Springboot框架的摄影作品分享活动参与网站

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

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

vue基于Springboot框架的网上购物商城抽奖系统 商家

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

作者头像 李华
网站建设 2026/6/15 23:03:35

基于C51单片机红绿黄交通灯的设计

基于C51单片机红绿黄交通灯的设计 第一章 系统概述 传统红绿黄交通灯多依赖固定电路控制,时序单一且无法灵活调整,难以适配不同时段车流量变化,易在高峰时段引发路口拥堵。基于C51单片机的红绿黄交通灯系统,以低成本、高可靠性的C…

作者头像 李华
网站建设 2026/6/16 6:11:52

Java开发者AI转型路线图:从CRUD到AI架构师的4种路径+实战项目(建议收藏)

文章分析了Java开发者向AI大模型领域转型的必要性、优势与路径。指出Java开发者具备工程化思维和企业级开发经验等转型优势,可通过渐进式路径完成技术栈过渡。文章详细介绍了需要强化的数学基础、大模型专项能力,以及如何将Java工程经验转化为AI项目价值…

作者头像 李华