【编译原理】第8讲 语法制导翻译(习题答案)——MOOC哈尔滨工业大学陈鄞

语法制导翻译习题1

1

文法G[S]及其语法制导翻译定义如下:

 产生式                                        语义动作

S’ → S                                    print( S.num)

S → ( L)                                   S.num = L.num +1

S → a                                      S.num = 0

L →L( 1), S                                L.num = L( 1).num + S.num

L →S                                       L.num = S.num

若输入为( a,( a)),且采用自底向上的分析方法,则输出为( )。

  • A.

    0

  • B.

    1

  • C.

    2

  • D.

    4

C

 

2

有文法G及其语法制导翻译如下所示( 语义规则中的*和+分别是常规意义下的算术运算符):

   E→E( 1) ∧ T {E.val = E( 1).val * T.val}

   E→T        {E.val = T.val}

   T→T( 1)# n    {T.val = T( 1).val + n.val }

   T→ n        {T.val = n.val}

则分析句子3 ∧ 3 # 4其值为(  )。

  • A.

    10

  • B.

    21

  • C.

    14

  • D.

    24

B

 

3

有一语法指导定义如下:

S→bAb        print  “1”

A→( B        print  “2”

A→a          print  “3”

B→aA)        print  “4”

若输入序列为b( a( a( aa)))b,且采用自底向上的分析方法,则输出序列为(  )。

  • A.

    32224441

  • B.

    34242421

  • C.

    12424243 

  • D.

    34442212

B

 

4

有一语法指导定义如下,其中+表示符号连接运算:

S→B              print  B.vers

B→a               B.vers=a

B→b             B.vers=b

B→Ba            B.vers=a+B.vers

B→Bb            B.vers=b+B.vers

若输入序列为abab,且采用自底向上的分析方法,则输出序列为(  )。

  • A.

    aabb

  • B.

    abab

  • C.

    bbaa

  • D.

    baba

D

 

5

使用( )可以定义一个程序的意义。

  • A.

    语义规则

  • B.

    词法规则

  • C.

    产生规则

  • D.

    词法规则

A

 

6

以下说法正确的是( )。

  • A.

    语义规则中的属性有两种:综合属性与继承属性

  • B.

    终结符只有继承属性,它由词法分析器提供

  • C.

    非终结符可以有综合属性,但不能有继承属性

  • D.

    属性值在分析过程中可以进行计算,但不能传递

A

 

语法制导翻译习题2

1
 

关于将L-SDD转换为SDT的规则,以下选项中,正确的是( )。

  • A.

    将计算某个非终结符号A的继承属性的动作放在产生式的最后

  • B.

    将计算一个产生式左部符号的继承属性的动作放置在产生式的最后

  • C.

    将计算某个非终结符号A的继承属性的动作插入到产生式右部中紧靠在A的本次出现之前的位置上 

  • D.

    将每个语义动作都放在产生式的最后

C
2
 

以下说法不正确的是( )。

  • A.

    如果一个S-SDD的基本文法可以使用LR分析技术,那么它的SDT可以在LL语法分析过程中实现

  • B.

    如果一个S-SDD的基本文法可以使用LR分析技术,那么它的SDT可以在LR语法分析过程中实现

  • C.

    如果一个L-SDD的基本文法可以使用LL分析技术,那么它的SDT可以在LL语法分析过程中实现

  • D.

    如果一个L-SDD的基本文法可以使用LL分析技术,那么它的SDT可以在LR语法分析过程中实现

A
3
 

以下说法不正确的是( )。

  • A.

    使用语法制导翻译方案的编译程序能同时进行语法分析和语义分析

  • B.

    语法制导翻译方案( SDT )是在产生式右部中嵌入了程序片段( 称为语义动作)的CFG

  • C.

    SDD可以看作是SDT的具体实施方案

  • D.

    将一个S-SDD转换为SDT的方法是:将每个语义动作都放在产生式的最后

C
4
 

在非递归的预测分析过程中进行翻译,以下说法不正确的是( )。

  • A.

    要想在非递归的预测分析过程中进行翻译,需要扩展语法分析栈

  • B.

    非终结符A的继承属性和综合属性的计算时机不同

  • C.

    将非终结符A的继承属性和综合属性存放在不同的记录中

  • D.

    综合属性在A出现之前就可以计算

D
5
 

在非递归的预测分析过程中进行翻译,以下说法不正确的是( )。

  • A.

    要想在非递归的预测分析过程中进行翻译,需要扩展语法分析栈

  • B.

    综合记录用于存放非终结符综合属性值

  • C.

    动作记录,用来存放指向将被执行的语义动作代码的指针

  • D.

    综合属性存放在A本身的记录中

D
6
 

在非递归的预测分析过程中进行翻译,以下说法不正确的是( )。

  • A.

    分析栈中的每一个记录都对应着一段执行代码

  • B.

    综合记录出栈时,要将综合属性值复制给后面特定的语义动作

  • C.

    变量展开时( 即变量本身的记录出栈时),如果其含有继承属性,则要将继承属性值复制给后面特定的语义动作

  • D.

    继承属性在A的儿子们都分析完毕之后才能计算

D

  • 2
    点赞
  • 12
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值