2.2 节的练习--Compiler principles, technologys, &tools
2.2 节的练习
2.2.1
考虑下面的上下文无关文法:
S -> S S + | S S * | a
- 试说明如何使用该文法生成串 aa+a*
- 试为这个串构造一颗语法分析树
- ⧗ 该文法生成的语言是什么?试证明
解答
S->SS * ->SS + S * -> aS+ S * -> a a +S* -> a a + a *
- 把 a 看成是运算数,L = {支持加法和乘法的表达式的后缀表示形式}
2.2.2
下面各个文法生成什么语言?证明你的每一个答案
- S -> 0 S 1 | 0 1
- S -> + S S | - S S | a
- S -> S ( S ) S | ε
- S -> a S b S | b S a S | ε
- ⧗ S -> a | S + S | S S | S * | ( S )
解答
- L = {0n1n | n>=1}
- L = {支持加法和减法的表达式的前缀表达形式}
- L = {匹配括号的任意排列和嵌套的括号串,包括 ε}
- L = {数量相同的a和b组成的符号串,包括 ε}
- ?
2.2.3
上一题中哪些文法具有二义性
解答
- 没有
- 没有
有

有

有

2.2.4
为下面的各个语言构建无二义性的上下文无关文法。证明你的文法都是正确的。
- 用后缀方法表示的算数表达式
- 由逗号分隔开的左结合的标识符列表(标识符以 id 表示,以下同)
- 由逗号分隔开的右结合的标识符列表
- 有整数、标识符、4个二目运算符 +, -, *, / 构成的算数表达式
- ! 在上一题的运算符中增加单目+ 和单目-构成的算数表达式
解答
- E -> E E op | num
- list -> list , id | id
- list -> id , list | id
expr -> expr + term | expr - term | term
term -> term * factor | term / factor | factor
factor -> id | num | (expr)
注:单目加减运算的优先级最高
expr -> expr + term | expr - term | term
term -> term * unary | term / unary | unary
unary -> + factor | - factor
factor - > id | num | (expr)
2.2.5
证明:用下面文法生成的所有二进制串的值都能被3整除。(提示:对语法分析树的节点树木使用数学归纳法)
num -> 11 | 1001 | num 0 | num num
上面的文法是否能生成所有能被3整除的二进制串?
解答
证明
符合该文法的二进制串一定是由任意数量的 11,1001 和 0 组成的最左位不为0的序列
该序列的十进制和为:
sum
= Σn (21 + 20) * 2 n + Σm (23 + 20) * 2m
= Σn 3 * 2 n + Σm 9 * 2m
显然是能被3整除的
不是。二进制串10101,数值为21,可被3整除,但无法由文法推导出。
注: 还有更一般性的证法么?
2.2.6
为罗马数字构建一个上下文无关文法
注:该文法不考虑罗马数字的上下划线表示,故只能产生小于4k的数字
解答
规则参考 维基百科:罗马数字
根据wiki中讲述的规则,可以发现个位数的表示可以分为4类:
I, II, III | I V | V, V I, V II, V III | I X
即有产生式:
digit -> smallDigit | I V | V smallDigit | I X
smallDigit -> I | II | III | ε
其他数位的表示类似。
还可以发现:罗马数字和阿拉伯数字有比较简单的数位对应关系。
例如:
- XII - X, II - 10 + 2 - 12
- CXCIX - C, XC, IX - 100 + 90 + 9 - 199
- MDCCCLXXX - M, DCCC, LXXX - 1000 + 800 + 80 - 1880
根据这两个规律推导出产生式:
romanNum -> thousand hundred ten digit
thousand -> M | MM | MMM | ε
hundred -> smallHundred | C D | D smallHundred | C M
smallHundred -> C | CC | CCC | ε
ten -> smallTen | X L | L smallTen | X C
smallTen -> X | XX | XXX | ε
digit -> smallDigit | I V | V smallDigit | I X
smallDigit -> I | II | III | ε
2.2 节的练习--Compiler principles, technologys, &tools的更多相关文章
- Compiler Principles 语法分析
语法分析的两种思维方式:1:自顶向下分析 :从语法树的根部推下来一直推到需要确认的终结符号串为止:就是为了找到一个符号串的最左推导 自顶向下分析,因为文法有些是以非终结符开头的另外文法中还可能含有右部 ...
- ACM会议列表与介绍(2014/05/06)
Conferences ACM SEACM Southeast Regional Conference ACM Southeast Regional Conference the oldest, co ...
- Github上的1000多本免费电子书重磅来袭!
Github上的1000多本免费电子书重磅来袭! 以前 StackOverFlow 也给出了一个免费电子书列表,现在在Github上可以看到时刻保持更新的列表了. 瞥一眼下面的书籍分类目录,你就能 ...
- Github 的一个免费编程书籍列表
Index Ada Agda Alef Android APL Arduino ASP.NET MVC Assembly Language Non-X86 AutoHotkey Autotools A ...
- ASP.NET Core 中文文档 第二章 指南(8) 使用 dotnet watch 开发 ASP.NET Core 应用程序
原文:Developing ASP.NET Core applications using dotnet watch 作者:Victor Hurdugaci 翻译:谢炀(Kiler) 校对:刘怡(Al ...
- Hive安装(一)之环境配置
Hive Web Interface(HWI)简介:Hive自带了一个Web-GUI,功能不多,可用于效果展示,如果没有安装Hue的话,是个不错的选择. 由于hive-bin包中没有包含HWI的页面, ...
- Ant自动编译打包&发布 android项目
Eclipse用起来虽然方便,但是编译打包android项目还是比较慢,尤其将应用打包发布到各个渠道时,用Eclipse手动打包各种渠道包就有点不切实际了,这时候我们用到Ant帮我们自动编译打包了. ...
- Core Java Volume I — 3.4. Variables
3.4. VariablesIn Java, every variable has a type. You declare a variable by placing the type first, ...
- 搭建hive1.2.1图形界面
下载:apache-hive-1.2.1-src.tar apache-hive-1.2.1-src.tar 解压,cd apache-hive-1.2.1-src/hwi 命令:jar cfM hi ...
随机推荐
- 【转】Nginx 安装配置
Nginx("engine x")是一款是由俄罗斯的程序设计师Igor Sysoev所开发高性能的 Web和 反向代理 服务器,也是一个 IMAP/POP3/SMTP 代理服务器. ...
- Ubuntu user switch
To list all users you can use: cut -d: -f1 /etc/passwd To add a new user you can use: sudo adduser n ...
- 你会用Python做出装逼的东西吗
如果我回答:“用Python很牛逼,但不能做出装逼的东西”,那大家来学习“小白的Python入门教程 ”,还有多少意义? 所以,为了让装逼的小船升级为牛逼的巨轮,让大家学完“小白的Python入门教程 ...
- 模仿MFC封装Windows API
.... 最后添加了两个按钮,分别处理每个按钮的单击事件时,走了弯路,本来想的是在QButton中重写OnLButtonDown方法,但是,无法区分是那个按钮.参考这篇文章: http://zhida ...
- Python OpenCV —— Modifying
一些索引和修改图像像素点数据等的操作,可打印观察运行结果. # -*- coding: utf-8 -*- """ Created on Wed Sep 28 00:11 ...
- chrome49 新特性 chrome.org转载
Transitioning from SPDY to HTTP/2 Thursday, February 11, 2016 Last year we announced our intent to e ...
- OD调试篇9
渐渐地要用比较高明一点的方法去破解软件了 那好,看看今天的程序先 先载入 测试下程序 发现这是一个未注册版本的程序,注册也不让注册,注册就跳出You have rntered an invalid ...
- EntityFramework 基础的crud
EntityFramework 基础的crud操作 根据上一张实体映射的demo学习基础的crud操作 1.增加 BlogDbContext dbContext = new BlogDbContext ...
- JAVA中精确计算金额BigDecimal
package com.chauvet.utils; import java.math.BigDecimal; import java.text.DecimalFormat; import java. ...
- windows下在yii中使用mongodb
1.编译或下载对应dll动态链接库拓展文件,下载地址:点我,不知道如何编译windows下的dll拓展->点我 2.找到web服务器软件,如apache,nginx等webserver处理浏览器 ...