- 1、本文档共6页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
编译原理独立作业
2010.5
一、简答题
构造一个文法使其生成的语言是不允许0打头的偶正整数集合。
2、文法:,,,构造句型的语法树,并指出该句型的短语、直接短语、句柄、素短语和最左素短语。
某LL(1)文法的预测分析表如下,请在下述分析过程表中填入输入串( a , a )$ 的分析过程。
a ^ , ( ) $ S S?a S?^ S?(A) A A?SB A?SB A?SA B B?,SB B?ε 分析过程表:
步骤 符号栈 输入串 动作 文法:,,,,,求广文法中LR(1)项目集的初态项目集I0。:,,,求出各非终结符的FISTVT和LASTVT集合。
二、分析题:
1、构造自动机,使得它能识别字母表{0,1}上以00结尾的符号串,将构造的自动机确定化,并写出相应的正规文法。
2、文法: ,写出每个非终结符的FIRST集和FOLLOW集,并判断该文法是否为LL(1)文法。
3、若有文法:
(1)试证明该文法是SLR(1) 文法,并构造SLR(1)分析表。
(2)给出输入串aa# 的分析过程。
参考答案
简答题
1、构造一个文法使其生成的语言是不允许0打头的偶正整数集合。
2、文法:,,,构造句型的语法树,并指出该句型的短语、直接短语、句柄、素短语和最左素短语。
短语:T,T-T,i,T*i,T-T+T*i
直接短语:T, i
句柄: T
素短语(P72):T-T,i
最左素短语:T-T
某LL(1)文法的预测分析表如下,请在下述分析过程表中填入输入串( a , a )$ 的分析过程。
a ^ , ( ) $ S S?a S?^ S?(A) A A?SB A?SB A?SA B B?,SB B?ε
(P68)
分析过程表:
步骤 符号栈 输入串 动作 1 $S (a,a)$ 符号栈出栈,对应产生式反向进栈 2 $)A( (a,a)$ 匹配 3 $)A a,a)$ 栈顶出栈,读下一个符号 4 $)BS a,a)$ 对应产生式A?SB反向进栈 5 $)Ba a,a$ 匹配 $)B ,a)$ 栈顶出栈,读下一个符号 $)BS, ,a)$ 匹配 $)BS a)$ 栈顶出栈,读下一个符号 $)Ba a)$ 匹配 $)B )$ 栈顶出栈,读下一个符号 $) )$ B?ε出栈 $) )$ 匹配,出栈 $ $ 匹配,分析成功 4、文法:,,,,,求广文法中LR(1)项目集的初态项目集I0
5. 文法:,,,求出各非终结符的FISTVT和LASTVT集合。
(P71)
FIRSTVT LASTVT S
G
H ; ( a
( a
( a ; ) a
) a
) a
二、分析题
1. 构造自动机,使得它能识别字母表{0,1}上以00结尾的符号串,将构造的自动机确定化,并写出相应的正规文法。(P41)
NFA:
0 1 S
A’
B’ S
S,A
S,A,B S,A
S,A,B
S,A,B S
S
S
最小化:
{S,A’}{B’}
0:{S}{A’}{B}
正规文法: ’
文法: ,写出每个非终结符的FIRST集和FOLLOW集,并判断该文法是否为LL(1)文法。
(P61)
FIRST(S)={a,b,d,e, }
FIRST(T)={a,b, }
FIRST(R)={d, }
FIRST(D)={a,b}
FOLLOW(S)={$ }
FOLLOW(T)=FOLLOW(S)={$ }
FOLLOW(R)={a,b,$}
FOLLOW(D)={d,$}
SELECT()={e}
SELECT()={a,b,d}
SELECT()={a,b}
SELECT()={$}
SELECT()={a,b}
SELECT()={d}
SELECT()={a}
SELECT()={d}
SELECT()∩SELECT()=
SELECT()∩SELECT()=
SELECT()∩SELECT()=
SELECT()∩SELECT()=
∴该文法是LL(1)文法。
3、若有文法:
(1)试证明该文法是SLR(1) 文法,并构造SLR(1)分析表。
(2)给出输入串aa# 的分析过程。
增广文法:
0) S?S 1) S?AB 2) A?aBa 3) A?? 4) B?bAb 5) B??
FOLLOW(S)={$} FOLLOW(A)={b,$} FOLLOW(B)
您可能关注的文档
最近下载
- 教育、科技、人才一体化与新质生产力发展.pptx VIP
- 2024年湖南水利水电职业技术学院单招职业技能测试题库含答案(研优卷).docx VIP
- 教育、科技、人才一体化视域下发展新质生产力的四重逻辑和实践路径.docx VIP
- 教育、科技、人才一体化视域下发展新质生产力的四重逻辑和实践路径.docx VIP
- 《大棚番茄基质槽式栽培技术规程》.docx
- 立体车库 毕业论文外文翻译.docx VIP
- 教育、科技、人才一体推进新质生产力发展.docx VIP
- 2024年湖南水利水电职业技术学院单招职业技能测试题库含答案(考试直接用).docx VIP
- 社交礼仪教程(第7版 微课版)课件 第五章 餐饮礼仪.pptx
- 2025清华:DeepSeek从入门到精通.pdf
文档评论(0)