ImageVerifierCode 换一换
格式:DOCX , 页数:16 ,大小:144.25KB ,
资源ID:5185725      下载积分:3 金币
快捷下载
登录下载
邮箱/手机:
温馨提示:
快捷下载时,用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)。 如填写123,账号就是123,密码也是123。
特别说明:
请自助下载,系统不会自动发送文件的哦; 如果您已付费,想二次下载,请登录后访问:我的下载记录
支付方式: 支付宝    微信支付   
验证码:   换一换

加入VIP,免费下载
 

温馨提示:由于个人手机设置不同,如果发现不能下载,请复制以下地址【https://www.bdocx.com/down/5185725.html】到电脑端继续下载(重复下载不扣费)。

已注册用户请登录:
账号:
密码:
验证码:   换一换
  忘记密码?
三方登录: 微信登录   QQ登录  

下载须知

1: 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。
2: 试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓。
3: 文件的所有权益归上传用户所有。
4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
5. 本站仅提供交流平台,并不能对任何下载内容负责。
6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

版权提示 | 免责声明

本文(太原理工大学编译原理实验复习进程.docx)为本站会员(b****5)主动上传,冰豆网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知冰豆网(发送邮件至service@bdocx.com或直接QQ联系客服),我们立即给予删除!

太原理工大学编译原理实验复习进程.docx

1、太原理工大学编译原理实验复习进程太原理工大学编译原理实验本科实验报告课程名称: 编译原理 实验项目:无符号数的词法分析程序(实验一)基本程序设计(实验二) 实验地点: 致远楼303 专业班级: 软件14XX 学号: 学生姓名: 指导教师: 冯秀芳 2017年 6 月27日一、实验目的和要求1 培养学生初步掌握编译原理实验的技能。2 验证所学理论、巩固所学知识并加深理解。3 对学生进行实验研究的基本训练。二、实验内容和原理实验一、 无符号数的词法分析程序(4学时)内容:掌握词法分析的基本思想,并用高级语言编写无符号数的词法分析程序。要求:从键盘上输入一串字符(包括字母、数字等),最后以“;”结束

2、,编写程序识别出其中的无符号数。无符号数文法规则可定义如下: .EE +- 0 1 2 3. 9 读无符号数的程序流程图见下图三 主要仪器设备PC机+Java语言编程环境四、实验结果与分析1.实验代码:package text1;import java.io.BufferedReader;import java.io.InputStreamReader;public class Text1 /* * param args */ public static void main(String args) throws Exception / TODO Auto-generated method s

3、tub int p = 0, w = 0, w1 = 0, j = 0, i = 0, d = 0, e = 1; double w2 = 0; String str; System.out.println(请输入一串字符以;结束:); BufferedReader buf = new BufferedReader( new InputStreamReader(System.in); str = buf.readLine(); char m = new char100; for (i = 0; i str.length(); i+) mi = str.charAt(i); i = 0; whi

4、le (i str.length() if (mi 57) i+; else do d = mi - 48; w = w * 10 + d; j+; i+; while (mi = 48 & mi = 48 & mi = 48 & mi 1) w2 = w / (Math.pow(10.0, j - 1); System.out.println(实型数为: + w2 + *10 + + (e * (p - j + 1); j = 0; w2 = 0; w = 0; p = 0; else System.out.println(您输入有误!); else if (mi = +) i+; if (

5、mi = 48 & mi = 48 & mi 1) w2 = w / (Math.pow(10.0, j - 1); System.out.println(实型数为: + w2 + *10 + + (e * (p + j - 1); j = 0; w2 = 0; w = 0; p = 0; else System.out.println(您输入有误!); else if (mi = 48 & mi = 48 & mi 1) w2 = w / (Math.pow(10.0, j - 1); System.out.println(实型数为: + w2 + *10 + + (e * (p + j -

6、 1); j = 0; w2 = 0; w = 0; p = 0; else System.out.println(您输入有误!); else i+; if (mi = 48 & mi = 48 & mi = 48 & mi = 48 & mi 1) w2 = w / (Math.pow(10.0, j - 1); System.out.println(实型数为: + w2 + w1 + *10 + + (e * (p - j + 1); w = 0; w1 = 0; j = 0; w2 = 0; p = 0; else System.out.println(实型数为: + w + . + w

7、1 + *10 + + (e * (p - j + 1); w = 0; w1 = 0; j = 0; w2 = 0; p = 0; else System.out.println(您输入有误!); else if (mi = +) i+; if (mi = 48 & mi = 48 & mi 1) w2 = w / (Math.pow(10.0, j - 1); System.out.println(实型数为: + w2 + w1 + *10 + + (e * (p + j - 1); w = 0; w1 = 0; j = 0; w2 = 0; p = 0; else System.out.

8、println(实型数为: + w + . + w1 + *10 + + (e * (p + j - 1); w = 0; w1 = 0; j = 0; w2 = 0; p = 0; else System.out.println(您输入有误!); else if (mi = 48 & mi = 48 & mi 1) w2 = w / (Math.pow(10.0, j - 1); System.out.println(实型数为: + w2 + w1 + *10 + + (e * (p + j - 1); w = 0; w1 = 0; j = 0; w2 = 0; p = 0; else Sy

9、stem.out.println(实型数为: + w + . + w1 + *10 + + (e * (p + j - 1); w = 0; w1 = 0; j = 0; w2 = 0; p = 0; else System.out.println(您输入有误!); else System.out.println(您输入有误!); 2.实验结果:一、实验目的和要求1 培养学生初步掌握编译原理实验的技能。2 验证所学理论、巩固所学知识并加深理解。3 对学生进行实验研究的基本训练。二、实验内容和原理实验二、 逆波兰式生成程序 内容:掌握语法分析的基本思想,并用高级语言编写逆波兰式生成程序(4学时)

10、 要求:利用逆波兰式生成算法编写程序,将从键盘上输入的算术表达式(中缀表达式)转化成逆波兰式。逆波兰表达式的生成过程涉及到运算符的优先级,下表中列出几个常用运算符的优先关系。如表所示的优先关系矩阵表示了+,-,*,/,(,)等七种运算符之间的相互优先关系。“、”三种符号分别代表“大于”、“小于”、“相等”三种优先关系。左边的“”与右边的“(”之间没有优先关系存在,所以表中为空白。逆波兰表达式生成算法的关键在于比较当前运算符与栈顶运算符的优先关系,若当前运算符的优先级高于栈顶运算符,则当前运算符入栈,若当前运算符的优先级低于栈顶运算符,则栈顶运算符退栈。下面给出了逆波兰表达式生成算法的流程图。(

11、为了便于比较相邻运算符的优先级,需要设立一个工作栈,用来存放暂时不能处理的运算符,所以又称运算符栈)。常用运算符优先关系矩阵 +-*/()+-*/()三、主要仪器设备PC机+Java语言编程环境四、实验结果与分析1.实验内容:package com_text4;import java.io.*;public class Text4 public static void main(String args) throws IOException / TODO Auto-generated method stub int i = 0, j = 0; String str; System.out.pr

12、intln(请输入一串中序表达式:); BufferedReader buf = new BufferedReader( new InputStreamReader(System.in); str = buf.readLine(); char m = new char20; for (int o = 0; o str.length(); o+) mo = str.charAt(o); for (int o = str.length(); o 20; o+) mo = ; char n = new charm.length; for (int o = 0; o n.length; o+) no

13、= ; System.out.println(逆波兰式为:); while (i = 1) j-; while (nj != ); j = j + 1; else if (isOperator(mi) while (isOperator(mi) if (nj = ) nj = mi; i+; else if (priority(nj,mi ) = 0) if (nj = () nj = ; i+; else if (n0 = ) System.out.println(Error); else if (nj != (&nj != ) System.out.print( nj); nj = ; i

14、f (j = 1) j-; i+; else if (nj != (&nj != ) System.out.print( nj); nj = ; if (j = 1) j-; else System.out.print(mi); i+; public static char priority(char operator1, char operator2) int a = 0, b = 0; char operatorPriorMatrix = , , , , , , , , , , , , , , , , , , , , , , , , , , , , , ; switch (operator

15、1) case +: a = 0; break; case -: a = 1; break; case *: a = 2; break; case /: a = 3; break; case (: a = 4; break; case ): a = 5; break; switch (operator2) case +: b = 0; break; case -: b = 1; break; case *: b = 2; break; case /: b = 3; break; case (: b = 4; break; case ): b = 5; break; return operatorPriorMatrixab; public static boolean isOperator(char operator) if (operator = + | operator = - | operator = * | operator = / | operator = ( | operator = ) return true; else return false; 2.实验结果:

copyright@ 2008-2022 冰豆网网站版权所有

经营许可证编号:鄂ICP备2022015515号-1