




版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
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 stubint p = 0, w = 0, w1 = 0,
3、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;while (i str.length() if (mi 57) i+; else d
4、o 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; elseSystem.out.println(您输入有误!); else if (mi = +) i+;if (mi = 48 & mi = 48 & mi 1)w2 = w / (Math.pow(10.0, j
5、 - 1);System.out.println(实型数为: + w2 + *10 + + (e * (p + j - 1);j = 0;w2 = 0;w = 0;p = 0; elseSystem.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 - 1);j = 0;w2 = 0;w = 0;p = 0; elseSystem.out.println(您输入有误!)
6、;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 + . + w1+ *10 + + (e * (p - j + 1);w = 0;w1 = 0;j = 0;w2 = 0;p = 0; elseSystem.ou
7、t.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.println(实型数为: + w + . + w1+ *10 + + (e * (p + j - 1);w = 0;w1 = 0;j = 0;w2 = 0;p = 0; els
8、eSystem.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 System.out.println(实型数为: + w + . + w1+ *10 + + (e * (p + j - 1);w = 0;w1 = 0;j = 0;w2 = 0;p = 0; elseSyst
9、em.out.println(您输入有误!); elseSystem.out.println(您输入有误!);2.实验结果:一、实验目的和要求1 培养学生初步掌握编译原理实验的技能。2 验证所学理论、巩固所学知识并加深理解。3 对学生进行实验研究的基本训练。二、实验内容和原理实验二、 逆波兰式生成程序 内容:掌握语法分析的基本思想,并用高级语言编写逆波兰式生成程序(4学时) 要求:利用逆波兰式生成算法编写程序,将从键盘上输入的算术表达式(中缀表达式)转化成逆波兰式。逆波兰表达式的生成过程涉及到运算符的优先级,下表中列出几个常用运算符的优先关系。如表所示的优先关系矩阵表示了+,-,*,/,(,)
10、等七种运算符之间的相互优先关系。“、”三种符号分别代表“大于”、“小于”、“相等”三种优先关系。左边的“”与右边的“(”之间没有优先关系存在,所以表中为空白。逆波兰表达式生成算法的关键在于比较当前运算符与栈顶运算符的优先关系,若当前运算符的优先级高于栈顶运算符,则当前运算符入栈,若当前运算符的优先级低于栈顶运算符,则栈顶运算符退栈。下面给出了逆波兰表达式生成算法的流程图。(为了便于比较相邻运算符的优先级,需要设立一个工作栈,用来存放暂时不能处理的运算符,所以又称运算符栈)。常用运算符优先关系矩阵 右关系左+-*/()+-*/()三、主要仪器设备PC机+Java语言编程环境四、实验结果与分析1.
11、实验内容:package com_text4;import java.io.*;public class Text4 public static void main(String args) throws IOException / TODO Auto-generated method stubint i = 0, j = 0;String str;System.out.println(请输入一串中序表达式:);BufferedReader buf = new BufferedReader(new InputStreamReader(System.in);str = buf.readLine(
12、);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 = ;System.out.println(逆波兰式为:);while (i = 1)j-; while (nj != );j = j + 1; else if (isOperator(mi) while (isOperator(mi) i
13、f (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 = ;if (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
14、 priority(char operator1, char operator2) int a = 0, b = 0;char operatorPriorMatrix = , , , , , , , , , , , , , , , , , , , , , , , , , , , , , ;switch (operator1) 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
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 2025年房地产经纪服务合同规范管理实务考核试卷
- 夏夜星空下的约定童话作文(15篇)
- 2025年旅游市场人工智能(AI)服务监管政策考核试卷
- 2025年健康中国行动实施-食品安全(农产品质量安全)考核试卷
- 考点解析人教版八年级物理上册第6章质量与密度-密度定向测评练习题(详解)
- 考点解析人教版八年级物理上册第6章质量与密度-质量定向练习试题(含答案解析版)
- 培养主体意识 提升儿童数学学习的成就感
- 浙江省主要城市经济高质量增长影响因素研究-基于社会嵌入视角和多层统计模型的分析
- 109.危重症患者团队执行力协作考核
- 票据质押贷款合同(标准版)
- 《铁路旅客运输》课件
- 2025年4月12日乌鲁木齐市人才引进面试真题及答案解析
- 高性能材料有限公司年产4.5万吨电子级异丙醇扩建项目环评资料环境影响
- 脑电图及临床应用
- Creo数字化建模技术(微课版)课件 2.0 Creo 6.0草绘环境
- 统编版道德与法治小学三年级上册教学设计
- 国家安全与青年担当
- 第十四章其他原因引起的语言障碍讲解
- 船舶机舱进水的应急处理
- 大学生化学实验竞赛试题及答案
- 班级管理(延边大学)知到智慧树章节答案
评论
0/150
提交评论