news 2026/4/18 4:58:18

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/18 15:46:36

MATLAB基本运算与运算符全解析

MATLAB作为工程计算、数据分析领域的主流工具,其灵活的运算体系和丰富的运算符是高效实现数值计算、矩阵操作的核心。 一、MATLAB运算基础:标量运算 标量运算是MATLAB最基础的运算形式,针对单个数值(整数、浮点数)的加…

作者头像 李华
网站建设 2026/4/18 11:20:54

LobeChat能否实现AI剪纸艺术家?民俗图案生成与文化寓意解读

LobeChat能否实现AI剪纸艺术家?民俗图案生成与文化寓意解读 在数字技术席卷全球的今天,一项流传千年的指尖艺术——中国剪纸,正悄然面临传承断层的风险。这门以红纸为媒、刀剪为笔的民间手艺,承载着“福寿双全”“年年有余”等朴素…

作者头像 李华
网站建设 2026/4/17 21:01:16

LobeChat ESG报告撰写辅助工具

LobeChat:构建企业级ESG报告智能撰写系统的实践路径 在“双碳”目标与全球可持续发展浪潮的推动下,ESG(环境、社会与治理)披露已从自愿性倡议转变为上市企业、大型集团的刚性合规要求。然而,现实中的ESG报告编制却常常…

作者头像 李华
网站建设 2026/4/18 7:58:31

基于单片机的直流电机PWM调速系统

基于单片机的直流电机PWM调速系统设计与实现 第一章 引言 直流电机凭借结构简单、启动转矩大、调速性能好等优势,广泛应用于工业自动化、智能设备、机器人等领域。传统直流电机调速方式(如串电阻调速)存在能耗高、调速精度低、响应迟缓等问题…

作者头像 李华
网站建设 2026/4/16 21:26:54

【珍藏版】大语言模型训练全流程详解:从基础模型到AI助手的蜕变

文章详细介绍了大语言模型(LLM)的三大训练阶段:预训练(无监督学习掌握语言规则和世界认知)、监督微调(SFT提升输出有用性和合规性)、以及RLHF(利用人类反馈优化回答质量)。随着DeepSeek等公司开源训练方法,我们可通过调整训练流程来革新大语言模型表现。…

作者头像 李华