当前位置:首页 » 编程软件 » 编译原理习题

编译原理习题

发布时间: 2025-06-02 16:41:49

① GitHub 上有哪些值得推荐的开源电子书

语言无关类
操作系统

  • 鸟哥的Linux私房菜 (简体)

  • Linux 系统高级编程

  • The Linux Command Line (中英文版)

  • Linux 设备驱动 (第三版)

  • 深入分析Linux内核源码

  • UNIX TOOLBOX

  • Docker中文指南

  • Docker —— 从入门到实践

  • FreeRADIUS新手入门

  • Mac 开发配置手册

  • FreeBSD 使用手册

  • Linux 命令行(中文版)

  • 智能系统
  • 一步步搭建物联网系统

  • web服务器
  • Nginx开发从入门到精通 (淘宝团队出品)

  • 版本控制
  • Git教程 (本文由 @廖雪峰 创作,如果觉得本教程对您有帮助,可以去 iTunes 购买)

  • git – 简易指南

  • 猴子都能懂的GIT入门

  • Git 参考手册

  • Pro Git

  • Git Magic

  • GotGitHub

  • Git Community Book 中文版

  • Mercurial 使用教程

  • HgInit (中文版)

  • 沉浸式学 Git

  • Git-Cheat-Sheet (感谢 @flyhigher139 翻译了中文版)

  • GitHub秘籍

  • NoSQL
  • NoSQL数据库笔谈 (PDF)

  • Redis 设计与实现

  • Redis 命令参考

  • 带有详细注释的 Redis 3.0 代码

  • 带有详细注释的 Redis 2.6 代码

  • The Little MongoDB Book

  • The Little Redis Book

  • Neo4j 简体中文手册 v1.8

  • Neo4j .rb 中文资源

  • MySQL
  • MySQL索引背后的数据结构及算法原理

  • 项目相关
  • 持续集成(第二版) (译言网)

  • 让开发自动化系列专栏

  • 追求代码质量

  • selenium 中文文档

  • Joel谈软件

  • 约耳谈软体(Joel on Software)

  • Web
  • 关于浏览器和网络的 20 项须知

  • 前端知识体系

  • 浏览器开发工具的秘密

  • Chrome 开发者工具中文手册

  • Chrome扩展开发文档

  • Grunt中文文档

  • 移动Web前端知识库

  • 正则表达式30分钟入门教程

  • 前端开发体系建设日记

  • 移动前端开发收藏夹

  • JSON风格指南

  • HTTP 接口设计指北

  • 前端资源分享(一)

  • 前端资源分享(二)

  • 前端代码规范 及 最佳实践

  • w3school教程整理

  • 大数据
  • 大数据/数据挖掘/推荐系统/机器学习相关资源

  • 编程艺术
  • 程序员编程艺术

  • 每个程序员都应该了解的内存知识(译)【第一部分】

  • 取悦的工序:如何理解游戏 (豆瓣阅读,免费书籍)

  • 其他
  • OpenWrt智能、自动、透明翻墙路由器教程

  • 语言相关类 AWK
  • awk程序设计语言

  • C/C++
  • C++ 并发编程指南 (@傅海平ICT)

  • Linux C编程一站式学习 (宋劲杉, 北京亚嵌教育研究中心)

  • CGDB中文手册

  • 100个gdb小技巧

  • 100个gcc小技巧

  • ZMQ 指南

  • How to Think Like a Computer Scientist (中英文版)

  • 跟我一起写Makefile(PDF)

  • GNU make中文手册

  • GNU make 指南

  • Google C++ 风格指南

  • C/C++ Primer (by @andycai)

  • 简单易懂的C魔法

  • Cmake 实践 (PDF版)

  • C++ FAQ LITE(中文版)

  • C++ Primer 5th Answers

  • CSS/HTML
  • 学习CSS布局

  • 通用 CSS 笔记、建议与指导

  • CSS参考手册

  • Emmet 文档

  • 前端代码规范 (腾讯alloyteam团队)

  • Dart
  • Dart 语言导览

  • Fortran
  • Fortran77和90/95编程入门

  • java
  • 实时 Java 系列

  • Apache Shiro 用户指南

  • 使用 Eclipse 和 Java SE 6 创建独立 Web Services 应用程序

  • 第 1 部分: Web Services 服务端应用程序

  • 第 2 部分: Web 服务客户端应用程序

  • JavaServer Faces 1.2 入门

  • 第 1 部分: 构建基本应用程序

  • 第 2 部分: JSF 生命周期、转换、检验和阶段监听器

  • 用 Eclipse Europa 进行 Web 开发

  • 第 1 部分: Eclipse Java EE

  • 第 2 部分: PHP 开发工具

  • 第 3 部分: Ruby Development Toolkit 和 RadRails

  • 使用 JavaServer Faces 构建 Apache Geronimo 应用程序

  • 第 1 部分: 使用 Eclipse 和 Apache MyFaces Core 构建基本的应用程序

  • 第 2 部分: 在 JavaServer Faces 中使用 Tomahawk

  • 第 3 部分: 使用 ajax4jsf 添加 Ajax 功能

  • 第 4 部分: 使用 Apache Trinidad 组件扩展 JSF

  • 第 5 部分: 将 JSF 应用程序与 Spring 集成

  • Apache Geronimo 和 Spring 框架

  • 第 1 部分: 开发方法学

  • 第 2 部分: 构建第一个应用程序

  • 第 3 部分: 集成 DAO 与 ORM

  • 第 4 部分: 混合使用 Spring AOP 和 Spring Web Flow

  • 第 5 部分: Spring MVC

  • 第 6 部分: Spring MVC:使用 Web 视图技术

  • 终极 mashup —— Web 服务和语义 Web

  • 第 1 部分: 使用与组合 Web 服务

  • 第 2 部分: 管理 Mashup 数据缓存

  • 第 3 部分: 理解 RDF 和 RDFs

  • 第 4 部分: 创建本体

  • 第 5 部分: 切换 Web 服务

  • Jersey 2.x 用户指南

  • MyBatis中文文档

  • JavaScript
  • Google JavaScript 代码风格指南

  • Airbnb JavaScript 规范

  • JavaScript 标准参考教程(alpha)

  • Javascript编程指南 (源码)

  • javascript 的 12 个怪癖

  • JavaScript 秘密花园

  • JavaScript核心概念及实践 (PDF) (此书已由人民邮电出版社出版发行,但作者依然免费提供PDF版本,希望开发者们去购买,支持作者)

  • 《JavaScript 模式》翻译,此书中文版有售,但是纸质书翻译的还没有这个版本翻译的好

  • 命名函数表达式探秘 (注:原文由为之漫笔翻译,原始地址无法打开,所以此处地址为我博客上的备份)

  • 学用 JavaScript 设计模式 (开源中国)

  • 深入理解JavaScript系列

  • ECMAScript 6 入门 (作者:阮一峰)

  • jQuery

  • jQuery 解构

  • 简单易懂的JQuery魔法

  • How to write jQuery plugin

  • Node.js

  • Node入门

  • 七天学会NodeJS

  • Nodejs Wiki Book (繁体中文)

  • express.js 中文文档

  • koa 中文文档

  • 使用 Express + MongoDB 搭建多人博客

  • Express框架

  • nodejs文档

  • Node.js 包教不包会

  • Learn You The Node.js For Much Win! (中文版)

  • Node debug 三法三例

  • underscore.js

  • Underscore.js中文文档

  • backbone.js

  • backbone.js入门教程 (PDF)

  • Backbone.js入门教程第二版

  • Developing Backbone.js Applications(中文版)

  • AngularJS

  • AngularJS最佳实践和风格指南

  • AngularJS中译本

  • AngularJS入门教程

  • 构建自己的AngularJS

  • 在Windows环境下用Yeoman构建AngularJS项目

  • zepto 简明中文手册

  • Sea.js

  • Hello Sea.js

  • CoffeeScript

  • CoffeeScript Cookbook

  • The Little Book on CoffeeScript中文版

  • ExtJS

  • Ext4.1.0 中文文档

  • Chrome扩展及应用开发

  • JavaScript入门教程

  • PHP
  • PHP调试技术手册(PDF)

  • XDebug 2中文手册(译) (CHM)

  • PHP之道

  • PHP 最佳实践

  • PHP安全最佳实践

  • 深入理解PHP内核

  • PHP扩展开发及内核应用

  • CodeIgniter 用户指南

  • Laravel4 中文文档

  • Laravel 入门

  • Symfony2中文文档 (未译完)

  • Phalcon中文文档(翻译进行中)

  • YiiBook几本Yii框架的在线教程

  • 简单易懂的PHP魔法

  • swoole文档及入门教程

  • iOS
  • iOS开发60分钟入门

  • iOS7人机界面指南

  • Google Objective-C Style Guide 中文版

  • iPhone 6 屏幕揭秘

  • Apple Watch开发初探

  • 马上着手开发 iOS 应用程序

  • 网易斯坦福大学公开课:iOS 7应用开发字幕文件

  • Android
  • Android Design(中文版)

  • Google Android官方培训课程中文版

  • Android学习之路

  • Python
  • 小白的Python教程

  • 简明Python教程

  • 零基础学Python

  • Python 2.7 官方教程中文版

  • Python 3.3 官方教程中文版

  • 深入 Python 3

  • PEP8 Python代码风格规范

  • Google Python 风格指南 中文版

  • Python入门教程 (PDF)

  • Python的神奇方法指南

  • 笨办法学 Python (PDF版下载)

  • Django 文档中文版

  • Django 最佳实践

  • The Django Book 中文版

  • web.py 0.3 新手指南

  • Web.py Cookbook 简体中文版

  • Dive Into Python 中文版

  • Bottle 文档中文版 (需翻墙)

  • Flask 文档中文版

  • Jinja2 文档中文版

  • Werkzeug 文档中文版

  • Flask之旅

  • Introction to Tornado 中文翻译

  • Python自然语言处理中文版 (感谢陈涛同学的翻译,也谢谢 @shwley 联系了作者)

  • Python 绘图库 matplotlib 官方指南中文翻译

  • Scrapy 0.25 文档

  • ThinkPython

  • Ruby
  • Ruby 风格指南

  • Rails 风格指南

  • 笨方法学 Ruby

  • Ruby on Rails 指南

  • Ruby on Rails 实战圣经

  • Ruby on Rails Tutorial 原书第 2 版 (本书网页版免费提供,电子版以 PDF、EPub 和 Mobi 格式提供购买,仅售 9.9 美元)

  • 编写Ruby的C拓展

  • Ruby 源码解读

  • Shell
  • Shell脚本编程30分钟入门

  • Go
  • Go编程基础

  • Go入门指南

  • 学习Go语言 (PDF)

  • Go Web 编程 (此书已经出版,希望开发者们去购买,支持作者的创作)

  • Go实战开发 (当我收录此项目时,作者已经写完第三章,如果读完前面章节觉得有帮助,可以给作者捐赠,以鼓励作者的继续创作)

  • Network programming with Go 中文翻译版本

  • Groovy
  • 实战 Groovy 系列

  • LaTeX
  • 一份其实很短的 LaTeX 入门文档

  • 一份不太简短的 LATEX 2ε 介绍 (PDF版)

  • LISP
  • ANSI Common Lisp 中文翻译版

  • Lua
  • Lua编程入门

  • Haskell
  • Real World Haskell 中文版

  • R
  • R语言忍者秘笈

  • Scala
  • Scala课堂 (Twitter的Scala中文教程)

  • Effective Scala(Twitter的Scala最佳实践的中文翻译)

  • Scala指南

  • Swift
  • The Swift Programming Language 中文版

  • Perl
  • Modern Perl 中文版

  • Perl 程序员应该知道的事

  • Prolog
  • 笨办法学Prolog

  • Vim中文文档

  • Vimscript
  • 笨方法学Vimscript 中译本

  • Vim中文文档

  • 读书笔记及其它 读书笔记
  • 编译原理(紫龙书)中文第2版习题答案

  • 把《编程珠玑》读薄

  • Effective C++读书笔记

  • Golang 学习笔记、Python 学习笔记、C 学习笔记 (PDF)

  • Jsoup 学习笔记

  • 学习笔记: Vim、Python、memcached

  • 图灵开放书翻译计划–C++、Python、Java等

  • 蒂姆·奥莱利随笔 (由译言网翻译,电子版免费)

  • Octave 入门 (PDF版)

  • SICP 解题集

  • 精彩博客集合

  • 正则表达式简明参考

② 编译原理习题,下图为什么a为句柄, 而不是最左面的b为句柄怎样理解句柄定义中的最左简单子树中的简

baSb的最右推导为:S->AB->ASb->bBSb->baSb

根据句柄定义:

所以a为baSb的句柄。

只有单层分支的子树称为简单子树。最左简单子树末端结点组成的符号串为句柄。

③ 编译原理中语法分析的一道问题

LALR我做着做着觉得不对,但SLR还是没问题的,这道题工程量非常庞大,想必以后也一定有人问,我就简要的带过吧,我归纳的解题步骤是:

  1. 构造LR(0)项目集规范族

  2. 求出FOLLOW集

  3. 根据规则圈出sj和rj对应的产生式

  4. 算出goto数

  5. 构造分析表

④ 编译原理试题

习题一、单项选择题
1、将编译程序分成若干个“遍”是为了 。
a.提高程序的执行效率
b.使程序的结构更加清晰
c.利用有限的机器内存并提高机器的执行效率
d.利用有限的机器内存但降低了机器的执行效率
2、构造编译程序应掌握 。
a.源程序 b.目标语言
c.编译方法 d.以上三项都是
3、变量应当 。
a.持有左值 b.持有右值
c.既持有左值又持有右值 d.既不持有左值也不持有右值
4、编译程序绝大多数时间花在 上。
a.出错处理 b.词法分析
c.目标代码生成 d.管理表格
5、 不可能是目标代码。
a.汇编指令代码 b.可重定位指令代码
c.绝对指令代码 d.中间代码
6、使用 可以定义一个程序的意义。
a.语义规则 b.词法规则
c.产生规则 d.词法规则
7、词法分析器的输入是 。
a.单词符号串 b.源程序
c.语法单位 d.目标程序
8、中间代码生成时所遵循的是- 。
a.语法规则 b.词法规则
c.语义规则 d.等价变换规则
9、编译程序是对 。
a.汇编程序的翻译 b.高级语言程序的解释执行
c.机器语言的执行 d.高级语言的翻译
10、语法分析应遵循 。
a.语义规则 b.语法规则
c.构词规则 d.等价变换规则
解答
1、将编译程序分成若干个“遍”是为了使编译程序的结构更加清晰,故选b。
2、构造编译程序应掌握源程序、目标语言及编译方法等三方面的知识,故选d。
3、对编译而言,变量既持有左值又持有右值,故选c。
4、编译程序打交道最多的就是各种表格,因此选d。
5、目标代码包括汇编指令代码、可重定位指令代码和绝对指令代码3种,因此不是目标代码的只能选d。
6、词法分析遵循的是构词规则,语法分析遵循的是语法规则,中间代码生成遵循的是语义规则,并且语义规则可以定义一个程序的意义。因此选a。
7、b 8、c 9、d 10、c
二、多项选择题
1、编译程序各阶段的工作都涉及到 。
a.语法分析 b.表格管理 c.出错处理
d.语义分析 e.词法分析
2、编译程序工作时,通常有 阶段。
a.词法分析 b.语法分析 c.中间代码生成
d.语义检查 e.目标代码生成
解答
1.b、c 2. a、b、c、e
三、填空题
1、解释程序和编译程序的区别在于 。
2、编译过程通常可分为5个阶段,分别是 、语法分析 、代码优化和目标代码生成。 3、编译程序工作过程中,第一段输入是 ,最后阶段的输出为 程序。
4、编译程序是指将 程序翻译成 程序的程序。 解答
是否生成目标程序 2、词法分析 中间代码生成 3、源程序 目标代码生成 4、源程序 目标语言
一、单项选择题
1、文法G:S→xSx|y所识别的语言是 。
a. xyx b. (xyx)* c. xnyxn(n≥0) d. x*yx*
2、文法G描述的语言L(G)是指 。
a. L(G)={α|S+ ⇒α , α∈VT*} b. L(G)={α|S*⇒α, α∈VT*}
c. L(G)={α|S*⇒α,α∈(VT∪VN*)} d. L(G)={α|S+ ⇒α, α∈(VT∪VN*)}
3、有限状态自动机能识别 。
a. 上下文无关文法 b. 上下文有关文法
c.正规文法 d. 短语文法
4、设G为算符优先文法,G的任意终结符对a、b有以下关系成立 。
a. 若f(a)>g(b),则a>b b.若f(a)<g(b),则a<b
c. a~b都不一定成立 d. a~b一定成立
5、如果文法G是无二义的,则它的任何句子α 。
a. 最左推导和最右推导对应的语法树必定相同
b. 最左推导和最右推导对应的语法树可能不同
c. 最左推导和最右推导必定相同
d. 可能存在两个不同的最左推导,但它们对应的语法树相同
6、由文法的开始符经0步或多步推导产生的文法符号序列是 。
a. 短语 b.句柄 c. 句型 d. 句子
7、文法G:E→E+T|T
T→T*P|P
P→(E)|I
则句型P+T+i的句柄和最左素短语为 。
a.P+T和i b. P和P+T c. i和P+T+i d.P和T
8、设文法为:S→SA|A
A→a|b
则对句子aba,下面 是规范推导。
a. SÞSAÞSAAÞAAAÞaAAÞabAÞaba
b. SÞSAÞSAAÞAAAÞAAaÞAbaÞaba
c. SÞSAÞSAAÞSAaÞSbaÞAbaÞaba
d. SÞSAÞSaÞSAaÞSbaÞAbaÞaba
9、文法G:S→b|∧(T)
T→T,S|S
则FIRSTVT(T) 。
a. {b,∧,(} b. {b,∧,)} c.{b,∧,(,,} d.{b,∧,),,}
10、产生正规语言的文法为 。
a. 0型 b. 1型 c. 2型 d. 3型
11、采用自上而下分析,必须 。
a. 消除左递归 b. 消除右递归 c. 消除回溯 d. 提取公共左因子
12、在规范归约中,用 来刻画可归约串。
a. 直接短语 b. 句柄 c. 最左素短语 d. 素短语
13、有文法G:E→E*T|T
T→T+i|i
句子1+2*8+6按该文法G归约,其值为 。
a. 23 B. 42 c. 30 d. 17
14、规范归约指 。
a. 最左推导的逆过程 b. 最右推导的逆过程
c. 规范推导 d. 最左归约的逆过程
[解答]
1、选c。
2、选a。
3、选c。
4、虽然a与b没有优先关系,但构造优先函数后,a与b就一定存在优先关系了。所以,由f(a)>g)(b)或f(a)<g(b)并不能判定原来的a与b之间是否存在优先关系:故选c。
5、如果文法G无二义性,则最左推导是先生长右边的枝叶:对于d,如果有两个不同的是了左推导,则必然有二义性。故选a。
6、选c。
7、由图2-8-1的语法树和优先关系可以看出应选b。

8、规范推导是最左推导,故选d。
9、由T→T,…和T→(… 得FIRSTVT(T))={(,,)};
由T→S得FIRSTVT(S)⊂FIRSTVT(T),而FIRSTVT(S)={b,∧,(};即
FIRSTVT(T)={b,∧,(,,}; 因此选c。
10、d 11、c 12、b 13、b 14、b
二、多项选择题
1、下面哪些说法是错误的 。
a. 有向图是一个状态转换图 b. 状态转换图是一个有向图
c.有向图是一个DFA d.DFA可以用状态转换图表示
2、对无二义性文法来说,一棵语法树往往代表了 。
a. 多种推导过程 b. 多种最左推导过程 c.一种最左推导过程
d.仅一种推导过程 e.一种最左推导过程
3、如果文法G存在一个句子,满足下列条件 之一时,则称该文法是二义文法。
a. 该句子的最左推导与最右推导相同
b. 该句子有两个不同的最左推导
c. 该句子有两棵不同的最右推导
d. 该句子有两棵不同的语法树
e.该句子的语法树只有一个
4、有一文法G:S→AB
A→aAb|ε
B→cBd|ε
它不产生下面 集合。
a. {anbmcndm|n,m≥0} b. {anbncmdm|n,m>0}
c. {anbmcmdn|n,m≥0} d. {anbncmdm|n,m≥0}
e. {anbncndn|n≥0}
5、自下而上的语法分析中,应从 开始分析。
a. 句型 b. 句子 c. 以单词为单位的程序
d. 文法的开始符 e. 句柄
6、对正规文法描述的语言,以下 有能力描述它。
a.0型文法 b.1型文法 c.上下文无关文法 d.右线性文法 e.左线性文法
解答 1、e、a、c 2、a、c、e 3、b、c、d 4、a、c 5、b、c 6、a、b、c、d、e
三、填空题
1、文法中的终结符和非终结符的交集是 。词法分析器交给语法分析器的文法符号一定是 ,它一定只出现在产生式的 部。
2、最左推导是指每次都对句型中的 非终结符进行扩展。
3、在语法分析中,最常见的两种方法一定是 分析法,另一是 分析法。
4、采用 语法分析时,必须消除文法的左递归。
5、 树代表推导过程, 树代表归约过程。
6、自下而上分析法采用 、归约、错误处理、 等四种操作。
7、Chomsky把文法分为 种类型,编译器构造中采用 和 文法,它们分别产生 和 语言,并分别用 和 自动机识别所产生的语言。
解答 1、空集 终结符 右
2、最左
3、自上而上 自下而上
4、自上而上
5、语法 分析
6、移进 接受
7、4 2 型 3型 上下文无关语言 正规语言 下推自动机 有限
四、判断题
1、文法 S→aS|bR|ε描述的语言是(a|bc)* ( )
R→cS
2、在自下而上的语法分析中,语法树与分析树一定相同。 ( )
3、二义文法不是上下文无关文法。 ( )
4、语法分析时必须先消除文法中的左递归。 ( )
5、规范归约和规范推导是互逆的两个过程。 ( )
6、一个文法所有句型的集合形成该文法所能接受的语言。 ( )
解答 1、对 2、错 3、错 4、错 5、错 6、错
五、简答题
1、句柄 2、素短语 3、语法树 4、归约 5、推导
[解答]
1、句柄:一个句型的最左直接短语称为该句型的句柄。
2、素短语:至少含有一个终结符的素短语,并且除它自身之外不再含任何更小的素短语。
3、语法树:满足下面4个条件的树称之为文法G[S]的一棵语法树。
①每一终结均有一标记,此标记为VN∪VT中的一个符号;
②树的根结点以文法G[S]的开始符S标记;
③若一结点至少有一个直接后继,则此结点上的标记为VN中的一个符号;
④若一个以A为标记的结点有K个直接后继,且按从左至右的顺序,这些结点的标记分别为X1,X2,…,XK,则A→X1,X2,…,XK,必然是G的一个产生式。
4、归约:我们称αγβ直接归约出αAβ,仅当A→γ 是一个产生式,且α、β∈(VN∪VT)*。归约过程就是从输入串开始,反复用产生式右部的符号替换成产生式左部符号,直至文法开始符。
5、推导:我们称αAβ直接推出αγβ,即αAβÞαγβ,仅当A→ γ 是一个产生式,且α、β∈(VN∪VT)*。如果α1Þα2Þ…Þαn,则我们称这个序列是从α1至α2的一个推导。若存在一个从α1αn的推导,则称α1可推导出αn。推导是归约的逆过程。
六、问答题
1、给出上下文无关文法的定义。
[解答]
一个上下文无关文法G是一个四元式(VT,VN,S, P),其中:
●VT是一个非空有限集,它的每个元素称为终结符号;
●VN是一个非空有限集,它的每个元素称为非终结符号,VT∩VN=Φ;
●S是一个非终结符号,称为开始符号;
●P是一个产生式集合(有限),每个产生式的形式是P→α,其中,P∈VN,
α∈(VT∪VN)*。开始符号S至少必须在某个产生式的左部出现一次。
2、文法G[S]:
S→aSPQ|abQ
QP→PQ
bP→bb
bQ→bc
cQ→cc
(1)它是Chomsky哪一型文法?
(2)它生成的语言是什么?
[解答]
(1)由于产生式左部存在终结符号,且所有产生式左部符号的长度均小于等于产生式右部的符号长度,所以文法G[S]是Chomsky1型文法,即上下文有关文法。
(2)按产生式出现的顺序规定优先级由高到低(否则无法推出句子),我们可以得到:
SÞabQÞabc
SÞaSPQÞaabQPQÞaabPQQÞaabbQQÞaabbcQÞaabbcc
SÞaSPQÞaaSPQPQÞaaabQPQPQÞaaabPQQPQÞaaabPQPQQÞaaaPPQQQÞ
aaabbPqqqÞaaabbQQQÞaaabbbcQQÞaaabbbccQÞaaabbbccc
……
于是得到文法G[S]生成的语言L={anbncn|n≥1}
3、按指定类型,给出语言的文法。
L={aibj|j>i≥1}的上下文无关文法。
【解答】
(1)由L={aibj|j>i≥1}知,所求该语言对应的上下文无关文法首先应有S→aSb型产生式,以保证b的个数不少于a的个数;其次,还需有S→Sb或S→bS型的产生式,用以保证b的个数多于a的个数;也即所求上下文无关文法G[S]为:
G[S]:S→aSb|Sb|b
4、有文法G:S→aAcB|Bd
A→AaB|c
B→bScA|b
(1)试求句型aAaBcbbdcc和aAcbBdcc的句柄;
(2)写出句子acabcbbdcc的最左推导过程。
【解答】(1)分别画出对应两句型的语法树,如图2-8-2所示
句柄:AaB Bd

图2-8-2 语法树
(2)句子acabcbbdcc的最左推导如下:
SÞaAcBÞaAaBcBÞacaBcBÞacabcBÞacabcbScAÞacabcbBdcA
ÞacabcbbdcAÞacabcbbdcc
5、对于文法G[S]:
S→(L)|aS|a L→L, S|S
(1)画出句型(S,(a))的语法树。(2)写出上述句型的所有短语、直接短语、句柄和素短语。
【解答】
(1)句型(S,(a))的语法树如图2-8-3所示

(2)由图2-8-3可知:
①短语:S、a、(a)、S,(a)、(S,(a));
②直接短语:a、S;
③句柄:S;
④素短语:素短语可由图2-8-3中相邻终结符之间的优先关系求得,即;

因此素短语为a。
6、考虑文法G[T]:
T→T*F|F
F→F↑P|P
P→(T)|i
证明T*P↑(T*F)是该文法的一个句型,并指出直接短语和句柄。
【解答】
首先构造T*P↑(T*F)的语法树如图2-8-4所示。

由图2-8-4可知,T*P↑(T*F)是文法G[T]的一个句型。
直接短语有两个,即P和T*F;句柄为P。

一、单项选择题
1、词法分析所依据的是 。
a. 语义规则 b. 构词规则 c. 语法规则 d. 等价变换规则
2、词法分析器的输出结果是 。
a. 单词的种别编码 b. 单词在符号表中的位置
c. 单词的种别编码和自身值 d. 单词自身值
3、正规式M1和M2等价是指 。
a. M1和M2的状态数相等 b. M1和M2的有向弧条数相等
c. M1和M2所识别的语言集相等 d. M1和M2状态数和有向弧条数相等
4、状态转换图(见图3-6-1)接受的字集为 。

a. 以 0开头的二进制数组成的集合 b. 以0结尾的二进制数组成的集合
c. 含奇数个0的二进制数组成的集合 d. 含偶数个0的二进制数组成的集合
5、词法分析器作为独立的阶段使整个编译程序结构更加简洁、明确,因此, 。
a. 词法分析器应作为独立的一遍 b. 词法分析器作为子程序较好
c. 词法分析器分解为多个过程,由语法分析器选择使用 d. 词法分析器并不作为一个独立的阶段
解答 1、b 2、c 3、c 4、d 5、b
二、多项选择题
1、在词法分析中,能识别出 。
a. 基本字 b. 四元式 c. 运算符
d. 逆波兰式 e. 常数
2、令∑={a,b},则∑上所有以b开头,后跟若干个ab的字的全体对应的正规式为 。
a. b(ab)* b. b(ab)+ c.(ba)*b
d. (ba)+b e. b(a|b)
解答 1、a、c、e 2、a、b、d
三、填空题
1、确定有限自动机DFA是 的一个特例。
2、若二个正规式所表示的 相同,则认为二者是等价的。
3、一个字集是正规的,当且仅当它可由 所 。
解答 1、NFA 2、正规集 3、DFA(NFA)所识别
四、判断题
1、一个有限状态自动机中,有且仅有一个唯一终态。 ( )
2、设r和s分别是正规式,则有L(r|s)=L(r)|L(s)。 ( )
3、自动机M和M′的状态数不同,则二者必不等价。 ( )
4、确定的自动机以及不确定的自动机都能正确地识别正规集。 ( )
5、对任意一个右线性文法G,都存在一个NFA M,满足L(G)=L(M)。 ( )
6、对任意一个右线性文法G,都存在一个DFA M,满足L(G)=L(M)。 ( )
7、对任何正规表达式e,都存在一个NFA M,满足L(G)=L(e)。 ( )
8、对任何正规表达式e,都存在一个DFA M,满足L(G)=L(e)。 ( )
解答 1 、2、3、错 4、5、6、7、8、正确
五、基本题
1、设M=({x,y}, {a,b}, f,x,{y})为一非确定的有限自动机,其中f定义如下:
f(x,a)={x,y} f(x,b)={y}
f(y,a)=φ f(y,b)={x,y}
试构造相应的确定有限自动机M′。
解答:对照自动机的定义M=(S,Σ,f,S0,Z),由f的定义可知f(x,a)、f(y,b)均为多值函数,所以是一非确定有限自动机,先画出NFA M相应的状态图,如图3-6-2所示。

用子集法构造状态转换矩阵表3-6-3所示。
I Ia Ib
{x} {x,y} {y}
{y} — {x,y}
{x,y} {x,y} {x,y}
将转换矩阵中的所有子集重新命名而形成表3-6-4所示的状态转换矩阵。
表3-6-4 状态转换矩阵
a b
0 2 1
1 — 2
2 2 2
即得到M′=({0,1,2}, {a,b}, f,0, {1,2}),其状态转换图如图3-6-5所示。

将图3-6-5的DFA M′最小化。首先,将M′的状态分成终态组{1,2}与非终态组{0};其次,考察{1,2}。由于{1,2}a={1,2}b={2}⊂{1,2},所以不再将其划分了,也即整个划分只有两组{0},{1,2}:令状态1代表{1,2},即把原来到达2的弧都导向1,并删除状态2。最后,得到如图3-6-6所示化简DFA M′。

2、对给定正规式b*(d|ad)(b|ab)+,构造其NFA M;
解答:首先用A+=AA*改造正规式得:b*(d|ad)(b|ab)(b|ab)*;其次,构造该正规式的NFA M,如图3-6-7所示。

⑤ 如何学习编译原理

编译原理是本科计算机课程中最难的一门了,因为它实在是太抽象了,而且学过之后很容易忘记,但是它又是非常重要的一门课程,起到了承上启下的作用。
学习编译原理,不要死看课本,课本都是翻译国外的,读起来有点吃力。结合习题是比较好的,可以理解一些概念。
另外,可以用lex和yacc实现一个词法分析器和语法分析器,如果这两个实验跑通了,对你学习编译原理的学习非常有帮助。

⑥ 请教几个有关编译原理的习题!

答:

1. S -> aS | ε
2. S -> aS | Sb | ab

设 有字符串序列 abc, 而字符串 abc 符合是文法S.
abc 有两种推导 ① S -> Ac, A -> bc
② S -> aB, B -> bc
有两语法树,二义文法

不好意思忘记了短语、直接短语和句柄
课本上应该有

⑦ 编译原理习题求帮忙

⑧ 编译原理及编译程序构造课后习题答案 薛联凤

您好,《普通高校计算机专业精品教材系列:编译原理及编译程序构造(第2版)》介绍编译理论基础及其实现方法,强调语言的形式化定义、编译技术的各种概念及实现过程的具体方法。介绍过程以算法为核心,力求简单明了地反映编译的基础知识。从形式语言理论角度讨论词法分析和语法分析技术,为计算机软件工作者开发大型软件打下良好基础。《普通高校计算机专业精品教材系列:编译原理及编译程序构造(第2版)》以理论联系实际为宗旨,内容深入浅出,重点突出,并结合构造el语言的编译程序介绍一种常用而又简单的编译方法。

⑨ 编译原理 学的是什么

编译原理是计算机专业的一门重要专业课,旨在介绍编译程序构造的一般原理和基本方法。内容包括语言和文法、词法分析、语法分析、语法制导翻译、中间代码生成、存储管理、代码优化和目标代码生成。 编译原理是计算机专业设置的一门重要的专业课程。虽然只有少数人从事编译方面的工作,但是这门课在理论、技术、方法上都对学生提供了系统而有效的训练,有利于提高软件人员的素质和能力。 目前各个大学使用的教材机械工业出版社、国防工业出版社出版的《编译原理》。
编译原理课程
这门课程关注的是编译器方面的产生原理和技术问题,似乎和计算机的基础领域不沾边,可是编译原理却一直作为大学本科的 必修课程,同时也成为了研究生入学考试的必考内容。编译原理及技术从本质上来讲就是一个算法问题而已,当然由于这个问题十分复杂,其解决算法也相对复杂。 我们学的数据结构与算法分析也是讲算法的,不过讲的基础算法,换句话说讲的是算法导论,而编译原理这门课程讲的就是比较专注解决一种的算法了。在20世纪 50年代,编译器的编写一直被认为是十分困难的事情,第一Fortran的编译器据说花了18年的时间才完成。在人们尝试编写编译器的同时,诞生了许多跟 编译相关的理论和技术,而这些理论和技术比一个实际的编译器本身价值更大。就犹如数学家们在解决着名的哥德巴赫猜想一样,虽然没有最终解决问题,但是其间 诞生不少名着的相关数论。

热点内容
oracle存储过程导入数据 发布:2025-06-04 11:01:32 浏览:888
android的书籍推荐2015 发布:2025-06-04 11:00:45 浏览:707
设置什么密码wifi不会被破解 发布:2025-06-04 10:59:52 浏览:605
推特的初始密码是多少 发布:2025-06-04 10:53:51 浏览:961
黑茶如何存储 发布:2025-06-04 10:42:36 浏览:761
持续集成python 发布:2025-06-04 10:19:40 浏览:565
为什么我的安卓十一不能养猫 发布:2025-06-04 10:16:59 浏览:479
linuxlibreoffice 发布:2025-06-04 10:07:09 浏览:926
安卓微信聊天记录删除了怎么恢复官方 发布:2025-06-04 10:02:41 浏览:772
联想电脑室服务器 发布:2025-06-04 10:01:56 浏览:867