编译A卷-答案
合集下载
- 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
- 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
- 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
第 2 页 共 页
学院
姓名
学号
任课老师
考场教室__________选课号/座位号
………密………封………线………以………内………答………题………无………效……
6. 简述存储分配的 3 种方式,各举一个例子。 1) 静态分配: 变量与存储区域的绑定关系在编译时便可建立, 并完成存储分配。 例如: 静态变量的分配。 (2 分) 2) 栈式分配:当一个程序单元被激活时, 在栈顶分配其活动记录;当程序单元退出时,在栈顶将其活动 记录撤销。例如:半静态变量的分配。 (2 分) 3) 堆分配:由于动态变量的首地址、长度、类型等在编译时无法确定,在执行过程中也可能改变,对于 这些变量,必须分配在堆上。例如:C 中通过 malloc 分配的变量;某些语言中的动态变量等。 (1 分) 三、已知文法:(共 12 分) E→ T| E+T | E-T T→ F| T*F | T/F F→ (E) | i 1、证明 i+(E-T)*F 是该文法的一个句型; (3 分) 2、给出句型 i+(E-T)*F 的推导树; (3 分) 3、指出该句型的所有短语、直接短语和句柄。 (6 分) 答案
学院
姓名
学号
任课老师
考场教室__________选课号/座位号
………密………封………线………以………内………答………题………无………效……
电子科技大学 2010 -2011 学年第 2 学期期 末 考试 A 卷 答案及评分细则
课程名称:__编译原理_ 考试形式: 闭卷 考试日期: 2011 年 6 月 21 日 考试时长:120 分钟
第 4 页 共 页
学院
姓名
学号
任课老师
考场教室__________选课号/座位号
………密………封………线………以………内………答………题………无………效……
2. FIRST 集和 FOLLOW 集(每个集合 1 分) FIRST FOLLOW E (,e #,* F f ) F' ) *, T * *,) 3. 预测分析表(每行 1 分) e f * ( ) E E →e E→(F) F F→f F' F' F'→T F' F'→ T T→ *ET 4. 因为预测分析表无多重定义入口,所以文法 G 是 LL(1)文法。 (2 分) 七、设有文法 G(E): (共 15 分) E(L)|a LL,E|E 1、 列出 G(E)的 LR(0)项目集规范族。 (8 分) 2、构造此相应的 SLR(1)分析表。 (5 分) 3、该文法是否为 SLR(1)文法?为什么(2 分) 答案
2.
3.
4.
5.
6.
)
7.
C. 右递归 D. ε产生式 8. 下列哪种语法分析法适用于分析 LL(1)文法( A ) A. 预测分析法 B. LR 分析法 C. 算符优先分析法 D. 递归下降分析法 9. 项目 Aα·Bβ称为( C ) ,其中 B∈VN。 A. 移进项目 B. 归约项目 C. 待约项目 D. 接受项目 10. 代码生成时,节省一条指令 MOV Ri, x,节省的执行代价为( C ) 。 A. 0 B. 1 C. 2 D. 3
一、选择题(共 10 分,共 10 题,每题 1 分) 1. 编译程序是将高级语言程序翻译成( D )程序的翻译程序。 A. 机器语言 B. 汇编语言 C. 中间语言 D. 低级语言 强制式语言的理论基础是( A ) A. 冯.诺依曼体系结构 B. 数学函数 C. 数理逻辑谓词演算 D. 抽象数据类型 C 语言的以下哪种数据类型属于用户定义类型( C ) A. 整型 B. 实型 C. 数组型 D. 字符型 以下哪种数据类型是抽象数据类型( D ) A. Pascal 的变体记录 B. C 语言的结构 C. Java 的数组 D. C++的类 从文法开始符推导出的任意符号串是该文法的( C ) A. 短语 B. 句子 C. 句型 D. 句柄 一个句型对应的语法树中,有且仅有 2 层的子树的边缘,称为该句型的( A A. 直接短语 B. 短语 C. 素短语 D. 活前缀 在自上而下的分析过程中,下列哪种情况不会产生回溯( C ) A. 公共左因子 B. 左递归
第 1 页 共
页
学院
姓名
学号
任课老师
考场教室__________选课号/座位号
………密………封………线………以………内………答………题………无………效……
二、简答题(共 30 分,共 6 题,每题 5 分) 1. 什么是绑定,静态绑定和动态绑定有什么区别?
绑定:一个对象(或事物)与其各种属性建立起某种联系的过程。 (3 分) 静态绑定:凡是在编译时(运行前)能确定的属性称为静态属性。实体与静态属性之间的绑定在编译时 (运行前)完成,运行时不改变,称为静态绑定。 (1 分) 动态绑定:凡是在运行时才能确定的属性称为动态属性。实体与动态属性之间的绑定在运行时完成,称 为动态绑定。 (1 分) 评分标准:答出关键词属性、编译时、运行时即可得分。 2. 举例说明用户定义类型的 6 种聚合方法。 笛卡尔积:PASCAL 的记录;C 的结构。 有限映像:数组。 序列:串、顺序文件。 递归:指针。 判定或:PASCAL 的变体记录;C 的联合。 幂集:PASCAL 的集合。 评分标准:答出 6 种方式可得 4 分;举例酌情给分。 3. 简述编译的 5 大步骤的功能,以及各步骤的输入与输出。 1) 词法分析: 根据词法规则, 进行合法性检查; 从构成源程序的字符串中识别出单词符号。 字符串 → 单 词符号串(单词串、符号串) 2) 语法分析:根据语法规则,进行合法性检查;将单词符号串组合成各类语法单位,构造语法树。单词 符号串 → 语法树 3) 语义分析与中间代码生成:根据语义规则,进行合法性检查;进行初步的翻译,生成中间代码。语法 树 → 中间代码 4) 优化:对中间代码进行等价变换,使代码的效率更高。中间代码 → 优化后的中间代码 5) 目标代码生成:将中间代码翻译成目标代码(目标程序) 。中间代码 → 目标程序 评分标准:每个阶段各 1 分。 4. 若算符文法 G 的任何两个终结符 a 和 b 没有优先关系,或者至多只有=、<和>中的一个优先关系, 则称 G 为算符优先文法。 评分标准:算符文法、至多、=、<、>各 1 分。 5. 简述循环优化的 3 种方法,各举一个例子。 1) 代码外提:对 x:=op y 或 x:=y op z,如果 y、z 均为循环不变量(常数或定值点在 L 之外) ,则该运算 为循环不变运算,优化时将该运算提到循环入口结点之前所增设的结点中去。 (2 分) 2) 强度削弱:基本归纳变量 i 每循环一次增加或减少 c,与 i 同族的归纳变量 j 相应增加或减少 c1*c。计 算 j 的乘法可由加法来代替:j := j + c1*c (c1*c 为常数) 。 (2 分) 3) 删除归纳变量:用同族归纳变量作为判断条件,如基本归纳变量别无它用,则可将其删除。 (1 分) 例如:j = 10 * i + 5,判断条件为 i > 10 ,则 将 i > 10 改为 j > 105,同时删除 i 相关的语句。
第 5 页 共
页
学院
姓名
学号
任课老师
考场教室__________选课号/座位号
………密………封………线………以………内………答………题………无………效……
2、SLR(1)分析表如下: (5 分:错 4 个扣 1 分,直到扣完) action 0 1 2 3 4 5 6 7 8 a s3 s3 ( s2 s2 r2 s6 r4 r1 s3 s2 r3 r3 r2 s7 r4 r1 r2 ) b # acc 5 4 E 1 goto L
第 3 页 共
页
学院
姓名
学号
任课老师
考场教室__________选课号/座位号
………密………封………线………以………内………答………题………无………效……
四、给出下面语句 While a>b do if a>0 then a:= a-1 else b:= b+1; 翻译得到的中间代码序列,地址从 100 开始,一条代码占 1 个字节。(10 分) 答案(写成三地址代码也可,错一个扣 1 分,直到扣完)
1. E => E+T => E+T*F =>E+F*F=>E+(E)*F=> E+(E-T)*F=>T+(E-T)*F=> F+(E-T)*F=> i+(E-T)*F (3 分) 2. (3 分)
E
E
+
T
T
(
E
)
E
_
T
3. 短语:
i 是关于 F、T、E 的短语; E-T 是关于 E 的短语; (E-T)是关于 F、T 的短语; (E-T)* F 是关于 T 的短语; i +(E-T)* F 是关于 E 的短语。 (3 分) 直接短语: i 是关于 F 的直接短语;E-T 是关于 E 的直接短语。 (2 分) 句柄: i (1 分)
#
1、拓广文法(1 分)
0.E'→E 1. E(L) 2. Ea 3. LLbE 4. LE FOLLOW 集如下: (1 分) FOLLOW(E')= {#} FOLLOW(E)= { # ) b} FOLLOW(L)= {) b} LR(0)项目集规范族: (6 分:I0、I2、I4 各 1 分,其余各 0.5 分) I0=closure{E'→·E}= {E'→·E, E→·( L ), E→·a } I1=GO(I0, E)={ E'→E·} I2=GO(I0, ( )={ E→(·L), L→·LbE, L→·E, E→·( L ), E→·a }= GO(I2, ( )= GO(I7, ( ) I3=GO(I0, a)={ E→a·}= GO(I2, a)= GO(I7, a) I4=GO(I2, L)={ E→(L·), L→L·bE } I5=GO(I2,E)={ L→E·} I6=GO(I4, ) )={ E→ ( L )·} I7=GO(I4,b)={ L→Lb·E, E→·( L ), E→·a } I8=GO(I7,E)= { L→Lb E·}
100: 101: 102: 103: 104: 105: 106: 107: 108: 109: 110:
(j>, (j, (j>, (j, (-, (:=, (j, (+, (:=, (j,
a, b, 102 ) —, —, 110 ) a, 0, 104 ) —, —, 107 ) a, 1, t1 ) t1, —, a ) —, —, 100 ) b, 1, t2 ) t2, —, b ) —, —, 100 )
r1 8
3、 不存在多重入口,故该文法是 SLR(1)文法。 (2 分)
第 6 页 共
页
五、给出下述语句(if-then-else 语句)的翻译方案(语义子程序) 。 (共 8 分) S→if B then M S1 else N S2 (3 分) { backpatch(B.T,M.CODE); backpatch(B.F,N.CODE); S.CHAIN=merge(S1.CHAIN,N.CHAIN,S2.CHAIN) } M→ (2 分) { M.CODE =ip } N→ (3 分) { N.CHAIN=ip; emit(goto 0); N.CODE=ip } 六、已知文法 G(E): (共 15 分) E →(F)| e F → FT| f T → *ET 1、 消除文法的左递归得文法 G’; (1 分) 2、 求 G’中各非终结符的的 FIRST 集、FOLLOW 集; (8 分) 3、 构造预测分析表; (4 分) 4、 该文法是不是 LL(1)文法?为什么?(2 分) 答: 1.(1 分) G'(E) : E→(F)| e F→f F' F'→T F'| T→ *ET
学院
姓名
学号
任课老师
考场教室__________选课号/座位号
………密………封………线………以………内………答………题………无………效……
6. 简述存储分配的 3 种方式,各举一个例子。 1) 静态分配: 变量与存储区域的绑定关系在编译时便可建立, 并完成存储分配。 例如: 静态变量的分配。 (2 分) 2) 栈式分配:当一个程序单元被激活时, 在栈顶分配其活动记录;当程序单元退出时,在栈顶将其活动 记录撤销。例如:半静态变量的分配。 (2 分) 3) 堆分配:由于动态变量的首地址、长度、类型等在编译时无法确定,在执行过程中也可能改变,对于 这些变量,必须分配在堆上。例如:C 中通过 malloc 分配的变量;某些语言中的动态变量等。 (1 分) 三、已知文法:(共 12 分) E→ T| E+T | E-T T→ F| T*F | T/F F→ (E) | i 1、证明 i+(E-T)*F 是该文法的一个句型; (3 分) 2、给出句型 i+(E-T)*F 的推导树; (3 分) 3、指出该句型的所有短语、直接短语和句柄。 (6 分) 答案
学院
姓名
学号
任课老师
考场教室__________选课号/座位号
………密………封………线………以………内………答………题………无………效……
电子科技大学 2010 -2011 学年第 2 学期期 末 考试 A 卷 答案及评分细则
课程名称:__编译原理_ 考试形式: 闭卷 考试日期: 2011 年 6 月 21 日 考试时长:120 分钟
第 4 页 共 页
学院
姓名
学号
任课老师
考场教室__________选课号/座位号
………密………封………线………以………内………答………题………无………效……
2. FIRST 集和 FOLLOW 集(每个集合 1 分) FIRST FOLLOW E (,e #,* F f ) F' ) *, T * *,) 3. 预测分析表(每行 1 分) e f * ( ) E E →e E→(F) F F→f F' F' F'→T F' F'→ T T→ *ET 4. 因为预测分析表无多重定义入口,所以文法 G 是 LL(1)文法。 (2 分) 七、设有文法 G(E): (共 15 分) E(L)|a LL,E|E 1、 列出 G(E)的 LR(0)项目集规范族。 (8 分) 2、构造此相应的 SLR(1)分析表。 (5 分) 3、该文法是否为 SLR(1)文法?为什么(2 分) 答案
2.
3.
4.
5.
6.
)
7.
C. 右递归 D. ε产生式 8. 下列哪种语法分析法适用于分析 LL(1)文法( A ) A. 预测分析法 B. LR 分析法 C. 算符优先分析法 D. 递归下降分析法 9. 项目 Aα·Bβ称为( C ) ,其中 B∈VN。 A. 移进项目 B. 归约项目 C. 待约项目 D. 接受项目 10. 代码生成时,节省一条指令 MOV Ri, x,节省的执行代价为( C ) 。 A. 0 B. 1 C. 2 D. 3
一、选择题(共 10 分,共 10 题,每题 1 分) 1. 编译程序是将高级语言程序翻译成( D )程序的翻译程序。 A. 机器语言 B. 汇编语言 C. 中间语言 D. 低级语言 强制式语言的理论基础是( A ) A. 冯.诺依曼体系结构 B. 数学函数 C. 数理逻辑谓词演算 D. 抽象数据类型 C 语言的以下哪种数据类型属于用户定义类型( C ) A. 整型 B. 实型 C. 数组型 D. 字符型 以下哪种数据类型是抽象数据类型( D ) A. Pascal 的变体记录 B. C 语言的结构 C. Java 的数组 D. C++的类 从文法开始符推导出的任意符号串是该文法的( C ) A. 短语 B. 句子 C. 句型 D. 句柄 一个句型对应的语法树中,有且仅有 2 层的子树的边缘,称为该句型的( A A. 直接短语 B. 短语 C. 素短语 D. 活前缀 在自上而下的分析过程中,下列哪种情况不会产生回溯( C ) A. 公共左因子 B. 左递归
第 1 页 共
页
学院
姓名
学号
任课老师
考场教室__________选课号/座位号
………密………封………线………以………内………答………题………无………效……
二、简答题(共 30 分,共 6 题,每题 5 分) 1. 什么是绑定,静态绑定和动态绑定有什么区别?
绑定:一个对象(或事物)与其各种属性建立起某种联系的过程。 (3 分) 静态绑定:凡是在编译时(运行前)能确定的属性称为静态属性。实体与静态属性之间的绑定在编译时 (运行前)完成,运行时不改变,称为静态绑定。 (1 分) 动态绑定:凡是在运行时才能确定的属性称为动态属性。实体与动态属性之间的绑定在运行时完成,称 为动态绑定。 (1 分) 评分标准:答出关键词属性、编译时、运行时即可得分。 2. 举例说明用户定义类型的 6 种聚合方法。 笛卡尔积:PASCAL 的记录;C 的结构。 有限映像:数组。 序列:串、顺序文件。 递归:指针。 判定或:PASCAL 的变体记录;C 的联合。 幂集:PASCAL 的集合。 评分标准:答出 6 种方式可得 4 分;举例酌情给分。 3. 简述编译的 5 大步骤的功能,以及各步骤的输入与输出。 1) 词法分析: 根据词法规则, 进行合法性检查; 从构成源程序的字符串中识别出单词符号。 字符串 → 单 词符号串(单词串、符号串) 2) 语法分析:根据语法规则,进行合法性检查;将单词符号串组合成各类语法单位,构造语法树。单词 符号串 → 语法树 3) 语义分析与中间代码生成:根据语义规则,进行合法性检查;进行初步的翻译,生成中间代码。语法 树 → 中间代码 4) 优化:对中间代码进行等价变换,使代码的效率更高。中间代码 → 优化后的中间代码 5) 目标代码生成:将中间代码翻译成目标代码(目标程序) 。中间代码 → 目标程序 评分标准:每个阶段各 1 分。 4. 若算符文法 G 的任何两个终结符 a 和 b 没有优先关系,或者至多只有=、<和>中的一个优先关系, 则称 G 为算符优先文法。 评分标准:算符文法、至多、=、<、>各 1 分。 5. 简述循环优化的 3 种方法,各举一个例子。 1) 代码外提:对 x:=op y 或 x:=y op z,如果 y、z 均为循环不变量(常数或定值点在 L 之外) ,则该运算 为循环不变运算,优化时将该运算提到循环入口结点之前所增设的结点中去。 (2 分) 2) 强度削弱:基本归纳变量 i 每循环一次增加或减少 c,与 i 同族的归纳变量 j 相应增加或减少 c1*c。计 算 j 的乘法可由加法来代替:j := j + c1*c (c1*c 为常数) 。 (2 分) 3) 删除归纳变量:用同族归纳变量作为判断条件,如基本归纳变量别无它用,则可将其删除。 (1 分) 例如:j = 10 * i + 5,判断条件为 i > 10 ,则 将 i > 10 改为 j > 105,同时删除 i 相关的语句。
第 5 页 共
页
学院
姓名
学号
任课老师
考场教室__________选课号/座位号
………密………封………线………以………内………答………题………无………效……
2、SLR(1)分析表如下: (5 分:错 4 个扣 1 分,直到扣完) action 0 1 2 3 4 5 6 7 8 a s3 s3 ( s2 s2 r2 s6 r4 r1 s3 s2 r3 r3 r2 s7 r4 r1 r2 ) b # acc 5 4 E 1 goto L
第 3 页 共
页
学院
姓名
学号
任课老师
考场教室__________选课号/座位号
………密………封………线………以………内………答………题………无………效……
四、给出下面语句 While a>b do if a>0 then a:= a-1 else b:= b+1; 翻译得到的中间代码序列,地址从 100 开始,一条代码占 1 个字节。(10 分) 答案(写成三地址代码也可,错一个扣 1 分,直到扣完)
1. E => E+T => E+T*F =>E+F*F=>E+(E)*F=> E+(E-T)*F=>T+(E-T)*F=> F+(E-T)*F=> i+(E-T)*F (3 分) 2. (3 分)
E
E
+
T
T
(
E
)
E
_
T
3. 短语:
i 是关于 F、T、E 的短语; E-T 是关于 E 的短语; (E-T)是关于 F、T 的短语; (E-T)* F 是关于 T 的短语; i +(E-T)* F 是关于 E 的短语。 (3 分) 直接短语: i 是关于 F 的直接短语;E-T 是关于 E 的直接短语。 (2 分) 句柄: i (1 分)
#
1、拓广文法(1 分)
0.E'→E 1. E(L) 2. Ea 3. LLbE 4. LE FOLLOW 集如下: (1 分) FOLLOW(E')= {#} FOLLOW(E)= { # ) b} FOLLOW(L)= {) b} LR(0)项目集规范族: (6 分:I0、I2、I4 各 1 分,其余各 0.5 分) I0=closure{E'→·E}= {E'→·E, E→·( L ), E→·a } I1=GO(I0, E)={ E'→E·} I2=GO(I0, ( )={ E→(·L), L→·LbE, L→·E, E→·( L ), E→·a }= GO(I2, ( )= GO(I7, ( ) I3=GO(I0, a)={ E→a·}= GO(I2, a)= GO(I7, a) I4=GO(I2, L)={ E→(L·), L→L·bE } I5=GO(I2,E)={ L→E·} I6=GO(I4, ) )={ E→ ( L )·} I7=GO(I4,b)={ L→Lb·E, E→·( L ), E→·a } I8=GO(I7,E)= { L→Lb E·}
100: 101: 102: 103: 104: 105: 106: 107: 108: 109: 110:
(j>, (j, (j>, (j, (-, (:=, (j, (+, (:=, (j,
a, b, 102 ) —, —, 110 ) a, 0, 104 ) —, —, 107 ) a, 1, t1 ) t1, —, a ) —, —, 100 ) b, 1, t2 ) t2, —, b ) —, —, 100 )
r1 8
3、 不存在多重入口,故该文法是 SLR(1)文法。 (2 分)
第 6 页 共
页
五、给出下述语句(if-then-else 语句)的翻译方案(语义子程序) 。 (共 8 分) S→if B then M S1 else N S2 (3 分) { backpatch(B.T,M.CODE); backpatch(B.F,N.CODE); S.CHAIN=merge(S1.CHAIN,N.CHAIN,S2.CHAIN) } M→ (2 分) { M.CODE =ip } N→ (3 分) { N.CHAIN=ip; emit(goto 0); N.CODE=ip } 六、已知文法 G(E): (共 15 分) E →(F)| e F → FT| f T → *ET 1、 消除文法的左递归得文法 G’; (1 分) 2、 求 G’中各非终结符的的 FIRST 集、FOLLOW 集; (8 分) 3、 构造预测分析表; (4 分) 4、 该文法是不是 LL(1)文法?为什么?(2 分) 答: 1.(1 分) G'(E) : E→(F)| e F→f F' F'→T F'| T→ *ET