编译原理E 实验指导书Word下载.docx
- 文档编号:22824176
- 上传时间:2023-02-05
- 格式:DOCX
- 页数:12
- 大小:1.06MB
编译原理E 实验指导书Word下载.docx
《编译原理E 实验指导书Word下载.docx》由会员分享,可在线阅读,更多相关《编译原理E 实验指导书Word下载.docx(12页珍藏版)》请在冰豆网上搜索。
ForI中每个组Gdo
Begin
当且仅当对任意输入符号a,状态s和读入a后转换到I的同一组中;
/*最坏情况下,一个状态就可能成为一个组*/
用所有新形成的小组集代替I-new中的G;
end
(3)如果I-new=I,令I-final=I,再执行第(4)步,否则令I=I=new,重复步骤
(2)。
(4)在划分I-final的每个状态组中选一个状态作为该组的代表。
这些代表构成了化简后的DFA M'状态。
令s是一个代表状态,而且假设:
在DFAM中,输入为a时有从s到t转换。
令t所在组的代表是r,那么在M’中有一个从s到r的转换,标记为a。
令包含s0的状态组的代表是M’的开始状态,并令M’的接受状态是那些属于F的状态所在组的代表。
注意,I-final的每个组或者仅含F中的状态,或者不含F中的状态。
(5)如果M’含有死状态(即一个对所有输入符号都有刀自身的转换的非接受状态d),则从M’中去掉它;
删除从开始状态不可到达的状态;
取消从任何其他状态到死状态的转换。
四、基本要求
1、输入一个DFAM,输出一个与之等价的最小化的DFAM’,上机编程实现。
2、实验报告格式要求书写要点:
概要设计(总体设计思想);
详细设计:
程序主流程、DFA的存储格式(即数据结构)、关键函数的流程图;
结果分析(输入与输出结果、存在问题及有待改进善的地方、实验心得)
五、测试数据
输入下图的DFAM,得到其最简的DFAM’。
DFAM
六、实现提示:
(1)可将输入的DFA存放在外部文本文件中,也可以直接从NFA转换得到。
对DFA的最小化分两部分进行化简,即分别对状态(结点)和路径(弧)进行最小化,最后输出最小化的DFA。
(2)实现的数据结构:
用链表实现DFA的构造:
由结点链表和转换弧链表组成:
structnode//结点的定义
{intpos;
//结点在哪个组中
intnum;
//结点的序号
intaccept;
//结点是否为接受状态
structnode*next;
}NODE;
structarc//弧的定义
{intstart;
//开始的顶点位置
charinput;
//弧上所接受的输入字符
intend;
//结束的顶点位置
structarc*next;
}ARC;
Structgroups//分组后各结点所在组
{intn;
//属于哪个组
inti;
//在组中的位置
}GROUPs;
(3)实现方法:
根据accept的值为0还是1进行初次划分I,将accept为0的所有结点构建成一个链表,将accept为1的所有结点构建一个链表。
然后执行最小化函数,对每一个输入字符遍历以上个链表,对每个结点.num=弧.start的情况,查看该弧.end的组号是否相等,相等则不划分;
若不相等,则需进一步划分,构建新的链表等。
划分完成后选头结点为代表,删除结点链表上其他结点,并将弧线链表上需被删的弧.start或弧.end该为头结点。
实验2词法程序设计——DFA模拟程序
一、实验目的
通过实验教学,加深学生对所学的关于编译的理论知识的理解,增强学生对所学知识的综合应用能力,并通过实践达到对所学的知识进行验证。
通过对DFA模拟程序实验,使学生掌握词法分析的实现技术,及具体实现方法。
通过本实验加深对词法分析程序的功能及实现方法的理解。
二、实验环境
供Windows系统的PC机,可用C++/C#/Java等编程工具编写
三、实验内容
1、定义一个右线性正规文法,示例如(仅供参考)
G[S]:
S→aU|bVU→bV|aQ
V→aU|bQQ→aQ|bQ|
实验前要考虑清楚用哪种数据结构存储上述文法。
2、构造其有穷确定自动机,如
3、利用有穷确定自动机M=(K,Σ,f,S,Z)行为模拟程序算法,来对于任意给定的串,若属于该语言时,该过程经有限次计算后就会停止并回答“是”,若不属于,要么能停止并回答“不是”。
K:
=S;
c:
=getchar;
whilec<
>
eofdo
{K:
=f(K,c);
c:
};
ifKisinZthenreturn(‘yes’)
elsereturn(‘no’)
四、实验方式与要求
1、每位同学定义的语言或文法不同,上机编程实现
详细设计(程序主流程、自动机的存储格式、关键函数的流程图);
实验3语法程序设计
——判断文法是否是LL
(1)文法?
首先能让用户输入一个文法,然后让计算机自动判断是否是一个LL
(1)文法,通过实验教学,加深学生对所学的关于编译的理论知识的理解,增强学生对所学知识的综合应用能力,并通过实践达到对所学的知识进行验证。
。
三、实验步骤
1、让计算机接受一个文法,示例如(仅供参考):
G[S]为:
S→ABS→bC
A→εA→b
B→εB→aD
C→ADC→b
D→aSD→c
1.2、编程实现对上述文法是否是LL
(1)文法的判断,是则给出肯定回答,否则给出否定回答。
2.判别是否是LL
(1)文法
实验流程图如下:
实验4-5语法程序设计
——基于LL
(1)文法的预测分析表法DFA模拟程序
通过对基于LL
(1)文法的预测分析表法DFA模拟程序实验,使学生掌握确定的自上而下的语法分析的实现技术,及具体实现方法。
通过本实验加深对语词法分析程序的功能及实现方法的理解。
1、定义一个LL
(1)文法,示例如(仅供参考)
G[E]:
E→TE'
E'
→+TE'
|ε
T→FT'
T'
→*FT'
|ε
F→i|(E)
2、构造其预测分析表,如
3、LL
(1)文法的预测分析表的模型示意图
4、预测分析控制程序的算法流程
5、运行结果,示例如下
四、实验方式与要求
1、每位同学定义的文法不同,上机编程实现;
结果分析(输入与输出结果、存在问题及有待改进善的地方、实验心得).
实验6逆波兰式的产生及计算
一、实验目的:
将非后缀式用来表示的算术表达式转换为用逆波兰式来表示的算术表达式,并计算用逆波兰式来表示的算术表达式的值。
二、实验内容:
1.定义部分:
定义常量、变量、数据结构。
2.初始化:
设立算符优先分析表、初始化变量空间(包括堆栈、结构体、数组、临时变量等);
3.控制部分:
从键盘输入一个表达式符号串;
4.利用算符优先分析算法进行表达式处理:
根据算符优先分析表对表达式符号串进行堆栈(或其他)操作,输出分析结果,如果遇到错误则显示错误信息。
5.对生成的逆波兰式进行计算。
三、实验预习提示:
1、逆波兰式定义
将运算对象写在前面,而把运算符号写在后面。
用这种表示法表示的表达式也称做后缀式。
逆波兰式的特点在于运算对象顺序不变,运算符号位置反映运算顺序。
采用逆波兰式可以很好的表示简单算术表达式,其优点在于易于计算机处理表达式。
2、产生逆波兰式的前提
中缀算术表达式
3、逆波兰式生成的实验设计思想及算法
(1)首先构造一个运算符栈,此运算符在栈内遵循越往栈顶优先级越高的原则。
(2)读入一个用中缀表示的简单算术表达式,为方便起见,设该简单算术表达式的右端多加上了优先级最低的特殊符号“#”。
(3)从左至右扫描该算术表达式,从第一个字符开始判断,如果该字符是数字,则分析到该数字串的结束并将该数字串直接输出。
(4)如果不是数字,该字符则是运算符,此时需比较优先关系。
做法如下:
将该字符与运算符栈顶的运算符的优先关系相比较。
如果,该字符优先关系高于此运算符栈顶的运算符,则将该运算符入栈。
倘若不是的话,则将此运算符栈顶的运算符从栈中弹出,将该字符入栈。
(5)重复上述操作
(1)-
(2)直至扫描完整个简单算术表达式,确定所有字符都得到正确处理,我们便可以将中缀式表示的简单算术表达式转化为逆波兰表示的简单算术表达式。
四、逆波兰式计算的实验设计思想及算法
(1)构造一个栈,存放运算对象。
(2)读入一个用逆波兰式表示的简单算术表达式。
(3)自左至右扫描该简单算术表达式并判断该字符,如果该字符是运算对象,则将该字符入栈。
若是运算符,如果此运算符是二目运算符,则将对栈顶部的两个运算对象进行该运算,将运算结果入栈,并且将执行该运算的两个运算对象从栈顶弹出。
如果该字符是一目运算符,则对栈顶部的元素实施该运算,将该栈顶部的元素弹出,将运算结果入栈。
(4)重复上述操作直至扫描完整个简单算术表达式的逆波兰式,确定所有字符都得到正确处理,我们便可以求出该简单算术表达式的值。
五、实验步骤:
(一)准备:
1.阅读课本有关章节,
2.考虑好设计方案;
3.设计出模块结构、测试数据,初步编制好程序。
(二)上课上机:
将源代码拷贝到机上调试,发现错误,再修改完善。
第二次上机调试通过。
(三)程序要求:
程序输入/输出示例:
输出的格式如下:
(1)逆波兰式的生成及计算程序,编制人:
姓名,学号,班级
(2)输入一以#结束的中缀表达式(包括+—*/()数字#):
在此位置输入符号串如(28+68)*2#
(3)逆波兰式为:
28&
68+2*
(4)逆波兰式28&
68+2*计算结果为192
备注:
(1)在生成的逆波兰式中如果两个数相连则用&
分隔,如28和68,中间用&
分隔;
(2)在此位置输入符号串为用户自行输入的符号串。
注意:
1.表达式中允许使用运算符(+-*/)、分割符(括号)、数字,结束符#;
2.如果遇到错误的表达式,应输出错误提示信息(该信息越详细越好);
3.对学有余力的同学,测试用的表达式事先放在文本文件中,一行存放一个表达式,同时以分号分割。
同时将预期的输出结果写在另一个文本文件中,以便和输出进行对照。
兰亭序
永和九年,岁在癸丑,暮春之初,会于会稽山阴之兰亭,修禊事也。
群贤毕至,少长咸集。
此地有崇山峻岭,茂林修竹;
又有清流激湍,映带左右,引以为流觞曲水,列坐其次。
虽无丝竹管弦之盛,一觞一咏,亦足以畅叙幽情。
是日也,天朗气清,惠风和畅,仰观宇宙之大,俯察品类之盛,所以游目骋怀,足以极视听之娱,信可乐也。
夫人之相与,俯仰一世,或取诸怀抱,晤言一室之内;
或因寄所托,放浪形骸之外。
虽取舍万殊,静躁不同,当其欣于所遇,暂得于己,快然自足,不知老之将至。
及其所之既倦,情随事迁,感慨系之矣。
向之所欣,俯仰之间,已为陈迹,犹不能不以之兴怀。
况修短随化,终期于尽。
古人云:
“死生亦大矣。
”岂不痛哉!
每览昔人兴感之由,若合一契,未尝不临文嗟悼,不能喻之于怀。
固知一死生为虚诞,齐彭殇为妄作。
后之视今,亦犹今之视昔。
悲夫!
故列叙时人,录其所述,虽世殊事异,所以兴怀,其致一也。
后之览者,亦将有感于斯文。
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 编译原理E 实验指导书 编译 原理 实验 指导书