编译原理期末习题考试复习题目(重点三)

编译原理期末习题考试复习题目(重点三)

目录

编译原理期末习题考试复习题目(重点三)

三、判断题

四、简答题


 


三、判断题

(下列各题,你认为正确的,请在题干的括号内打“ √”,错的打“×”)

1计算机高级语言翻译成低级语言只有解释一种方式。         X

2在编译中进行语法检查的目的是为了发现程序中所有错误。   X

3甲机上的某编译程序在乙机上能直接使用的必要条件是甲机和乙机的操作系统功能完全相   同。   X

4.“用高级语言书写的源程序都必须通过编译,产生目标代码后才能投入运行”这种说法。(X)

5正则文法其产生式为AàaAàBb ABVNabVT V

6.产生式是用于定义词法成分的一种书写规则。                (X)

7.解释程序适用于 COBOL 和 FORTRAN 语言。              (X)

8.正规文法产生的语言都可以用上下文无关文法来描述。        (V)

9.如果一个文法存在某个句子对应两棵不同的语法树,则称这个文法是二义的。 (V)

10.编译程序是对高级语言程序的解释执行。                   (X)

11.一个有限状态自动机中,有且仅有一个唯一的终态。         (X)

12.语法分析时必须先消除文法中的左递归 。                  (X)

13.两个正规集相等的必要条件是他们对应的正规式等价。       (V )

14.设r和s分别是正规式,则有L(r|s)=L(r)L(s)。               (X)

15.确定的自动机以及不确定的自动机都能正确地识别正规集。   (V)

16.词法分析作为单独的一遍来处理较好。                     (X)

17.构造LR分析器的任务就是产生LR分析表。                 (V)

18.编译程序与具体的机器有关,与具体的语言无关。           (X)

19.每个文法都能改写为LL(1)文法。                           (X)

20递归下降法允许任一非终结符是直接左递归的。              V

21递归下降分析法是自顶向下分析方法。                       (V)

22.一个 LL(l)文法一定是无二义的。                          (V)

23.算符优先关系表不一定存在对应的优先函数。                (X)

24自底而上语法分析方法的主要问题是候选式的选择。          X

25LR分析方法是自顶向下语法分析方法。                     X

26简单优先文法允许任意两个产生式具有相同右部。            X

27若一个句型中出现了某产生式的右部,则此右部一定是该句型的句柄。(X

28一个句型的句柄一定是文法某产生式的右部。                V

29.在 SLR(1)分析法的名称中,S的含义是简单的。             (V)

30.综合属性是用于 “ 自上而下 ” 传递信息。                (X)

31.一个算符优先文法可能不存在算符优先函数与之对应。       (V)

32.LR分析法在自左至右扫描输入串时就能发现错误,但不能准确地指出出错地点。 (V)

33.规范归约和规范推导是互逆的两个过程。                   (V)

34.LR分析技术无法适用二义文法。                           (X)

35.逆波兰表示法表示表达式时无须使用括号。                  (V)

36.逆波兰法表示的表达式亦称后缀式 。                      (V)

38在程序中标识符的出现仅为使用性的。                      X

设∑为{a,b},则a,ba,{∑},Φ都是∑上的正规式。(X)

对于上下文无关文法G[S],若一定是一条产生式规则,其中  (X)

对于逆波兰后缀式,无论从哪头开始分析均可得到唯一正确的分解。(V)

LR(0)分析法是一种规范归约法。         (V)

算符优先分析法只能用来分析算符优先文法。 (V)

解释程序和编译程序一样,生成目标代码。  (X)

编译程序生成的目标代码只能是机器语言。  (X)

等价文法是指两个文法完全相同。          (X)

对于字母表Σ上的任一NFA M',必存在Σ上与NFA M' 等价的DFA M。(V)

每个文法都能改写为LL(1)文法。 (X)

不存在正规文法能产生语言:

四、简答题

  1. 什么是句子? 什么是语言?

答:G是一个给定的文法,S是文法的开始符号,如果

则称x是文法的一个句子。设G[S]是给定文法,则由文法G所定义的语言L(G)可描述为

2、已知文法G[E]为:

E→T|E+T|E-T

T→F|T*F|T/F

F→E|i

① 该文法的开始符号(识别符号)是什么?

②请给出该文法的终结符号集合VT和非终结符号集合VN。

找出句型T+T*F+i的所有短语、简单短语和句柄。

答:① 该文法的开始符号(识别符号)是E

    ②该文法的终结符号集合VT={+-*/、(、)、i}。 

              非终结符号集合VN={ETF}。 

    ③句型T+T*F+I的句柄为第一个T

3、已知文法G[S]为:

S→dAB

A→aA|a

B→Bb|ε

① G[S]产生的语言是什么?

G[S]能否改写为等价的正规文法?

答:① G[S]产生的语言是L(G[S])={da^nb^mn1,m0}

    ② G[S]能改写为等价的正规文法,其改写后的等价的

        正规文法G[Sˊ]为:     

Sˊ→dA     

A aA|aB|a     

B bB|b

5证明下面文法G[N]是二义性文法。       

G[N] N →SEE

       S →SDD

       E →0210

D →012

  1. 简述DFANFA有何区别 ?

答:

   主要区别在于,1.DFA没有ε转换;2.DFA的状态转换函数是单值映射,即当前状态输入一个字符后转换到下一个状态,而NFA的状态转换函数是非单值映射,也就是说当前状态输入一个字符后可以转换到下面N个状态。

  1. 试给出非确定自动机的定义。

答:

   一个非确定的有穷自动机(NFAM是一个五元组:M=S,Σ,moves0 F)。 

其中: 

1. 一个有限的状态集合S; 

2. Σ是一个输入符号集合,ε不在Σ中; 

3. move是状态转换函数,是在S×Σ*S的子集的映射,即,

答:① G[S]产生的语言是L(G[S])={da^nb^mn1,m0}

    ② G[S]能改写为等价的正规文法,其改写后的等价的

        正规文法G[Sˊ]为:     

Sˊ→dA     

A aA|aB|a     

B bB|b

5证明下面文法G[N]是二义性文法。       

G[N] N →SEE

       S →SDD

       E →0210

D →012

  1. 简述DFANFA有何区别 ?

答:

   主要区别在于,1.DFA没有ε转换;2.DFA的状态转换函数是单值映射,即当前状态输入一个字符后转换到下一个状态,而NFA的状态转换函数是非单值映射,也就是说当前状态输入一个字符后可以转换到下面N个状态。

  1. 试给出非确定自动机的定义。

答:

   一个非确定的有穷自动机(NFAM是一个五元组:M=S,Σ,moves0 F)。 

其中: 

1. 一个有限的状态集合S; 

2. Σ是一个输入符号集合,ε不在Σ中; 

3. move是状态转换函数,是在S×Σ*S的子集的映射,即,

答:① G[S]产生的语言是L(G[S])={da^nb^mn1,m0}

    ② G[S]能改写为等价的正规文法,其改写后的等价的

        正规文法G[Sˊ]为:     

Sˊ→dA     

A aA|aB|a     

B bB|b

5证明下面文法G[N]是二义性文法。       

G[N] N →SEE

       S →SDD

       E →0210

D →012

  1. 简述DFANFA有何区别 ?

答:主要区别在于,1.DFA没有ε转换;2.DFA的状态转换函数是单值映射,即当前状态输入一个字符后转换到下一个状态,而NFA的状态转换函数是非单值映射,也就是说当前状态输入一个字符后可以转换到下面N个状态。

  1. 试给出非确定自动机的定义。

答: 一个非确定的有穷自动机(NFAM是一个五元组:M=S,Σ,moves0 F)。 

其中: 

1. 一个有限的状态集合S; 

2. Σ是一个输入符号集合,ε不在Σ中; 

3. move是状态转换函数,是在S×Σ*→S的子集的映射,即,

表明在某状态下对于某输入符号可能有多个后继状态; 

4. s0是唯一的开始状态;  

5. F是接受(或终止)状态集合,且F属于S一个子集。

9为正规式(a|b*a(a|b) 构造一个等价的确定的有限自动机。

答:

  1. 构造正规式相应的 NFA : 1(0|1)*101

12、已知文法 G[S] 为:

     S→dAB

     A→aA|a

     B→Bb|ε

   G[S] 产生的语言是什么?

  1. 编译过程一般分为几个阶段?各阶段的输入输出分别为什么?

15、在LL(1)分析法中,LL分别代表什么含义?

答:

    第一个L代表从左到右的扫描,第二个L代表每次进行最左推导。

16、文法G为:

   S→aAB

   A→a

   B→ α|β|γ

则判断G为LL(1)文法的条件是:

17、文法G=({A, B, S}, {a, b, c}, P, S)

   其中P为:

   S→Ac|aB

   A→ab

   B→bc

   该文法是二义的吗?说明理由。

18、文法G=({E}, {+, *, i, (, )}, P, E)其中P为:

   E→i

   E→E+E

   E→E*E

   E→(E)

该文法是二义的吗?说明理由。

  1. 自顶向下分析思想是什么?

答:

从开始符出发导出句型并一个符号一个符号地与给定终结符串进行匹配。如果全部匹配成功,则表示开始符号可推导出给定的终结符串。因此判定给定终结符号串是正确句子。

25简单优先方法基本思想是什么?

28语法制导翻译方法的基本思想是什么?

33给定下列中缀式,分别写出等价的后缀式和四元式(运算符优先级按常规理解)

(1)(ab*c)/(ab)d

  • 10
    点赞
  • 121
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 4
    评论
编译原理期末考试主要涵盖了编译原理课程所学的知识点和理论基础,以及相关的实践能力。在考试中,通常会包含选择题、填空题、简答题和编程题等不同类型的题。 选择题考察学生对编译原理相关概念的理解和掌握程度,例如词法分析、语法分析、语义分析、中间代码生成、代码优化和标代码生成等方面的知识。 填空题要求学生填写编译过程中的关键参数、关键步骤或关键算法的具体数值或表达式,考察学生对具体细节的掌握情况。 简答题会提出一些编译原理的基本问题,要求学生用自己的语言进行解释和回答,主要考察学生对编译原理的原理和概念的理解和应用能力。 编程题是考察学生对编译原理知识的实际应用能力,通常要求学生编写一个简单的编译器或解释器的某个功能模块,完成对源代码的词法分析、语法分析、语义分析等操作。 在备考阶段,需要重点复习编译原理的基本概念、算法和原理,练习做一些相关的习题和编程实践,熟悉不同类型的题形式和解题思路。此外,深入理解编译原理的原理和实践,尝试设计和实现一个简单的编译器,也有助于加深对知识的理解和应用能力的提升。 总之,编译原理期末考试是对学生在编译原理课程上所学的理论和实践能力的检验,通过复习和实践的准备,能更好地应对考试的各个环节,取得好成绩。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

叁佰_542586

天桥底下的穷屌丝和他の破鞋草席

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值