欢迎来到淘文阁 - 分享文档赚钱的网站! | 帮助中心 好文档才是您的得力助手!
淘文阁 - 分享文档赚钱的网站
全部分类
  • 研究报告>
  • 管理文献>
  • 标准材料>
  • 技术资料>
  • 教育专区>
  • 应用文书>
  • 生活休闲>
  • 考试试题>
  • pptx模板>
  • 工商注册>
  • 期刊短文>
  • 图片设计>
  • ImageVerifierCode 换一换

    太原理工大学编译原理实验(13页).doc

    • 资源ID:35918727       资源大小:382.50KB        全文页数:14页
    • 资源格式: DOC        下载积分:15金币
    快捷下载 游客一键下载
    会员登录下载
    微信登录下载
    三方登录下载: 微信开放平台登录   QQ登录  
    二维码
    微信扫一扫登录
    下载资源需要15金币
    邮箱/手机:
    温馨提示:
    快捷下载时,用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)。
    如填写123,账号就是123,密码也是123。
    支付方式: 支付宝    微信支付   
    验证码:   换一换

     
    账号:
    密码:
    验证码:   换一换
      忘记密码?
        
    友情提示
    2、PDF文件下载后,可能会被浏览器默认打开,此种情况可以点击浏览器菜单,保存网页到桌面,就可以正常下载了。
    3、本站不支持迅雷下载,请使用电脑自带的IE浏览器,或者360浏览器、谷歌浏览器下载即可。
    4、本站资源下载后的文档和图纸-无水印,预览文档经过压缩,下载后原文更清晰。
    5、试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓。

    太原理工大学编译原理实验(13页).doc

    -本科实验报告课程名称: 编译原理 实验项目:无符号数的词法分析程序(实验一)基本程序设计(实验二) 实验地点: 致远楼303 专业班级: 软件14XX 学号: 学生姓名: 指导教师: 冯秀芳 2017年 6 月27日一、实验目的和要求1 培养学生初步掌握编译原理实验的技能。2 验证所学理论、巩固所学知识并加深理解。3 对学生进行实验研究的基本训练。二、实验内容和原理实验一、 无符号数的词法分析程序(4学时)内容:掌握词法分析的基本思想,并用高级语言编写无符号数的词法分析程序。要求:从键盘上输入一串字符(包括字母、数字等),最后以“;”结束,编写程序识别出其中的无符号数。无符号数文法规则可定义如下: <无符号数><无符号实数><无符号整数> <无符号实数><无符号整数>.<数字串>E<比例因子><无符号整数>E<比例因子> <比例因子><有符号整数> <有符号整数>+-<无符号整数> <无符号整数><数字串> <数字串><数字><数字> <数字>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, 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 < 48 | mi > 57) i+; else do d = mi - 48;w = w * 10 + d;j+;i+; while (mi >= 48 && mi <= 57);/ System.out.println("chesi"+mi);if (mi != '.') if (mi != 'E') System.out.println("整型数为:" + w);j = 0;w = 0; else i+;if (mi = '-') e = -1;i+;if (mi >= 48 && mi <= 57) do d = mi - 48;p = p * 10 + d;i+; while (mi >= 48 && mi <= 57);if (j > 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 <= 57) do d = mi - 48;p = p * 10 + d;i+; while (mi >= 48 && mi <= 57);if (j > 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 >= 48 && mi <= 57) do d = mi - 48;p = p * 10 + d;i+; while (mi >= 48 && mi <= 57);if (j > 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 i+;if (mi >= 48 && mi <= 57) do d = mi - 48;w1 = w1 * 10 + d;/ j = j + 1;i+; while (mi >= 48 && mi <= 57); elseSystem.out.println("您输入有误!");if (mi != 'E') System.out.println("小数为:" + w + '.' + w1);w = 0;w1 = 0;j = 0; else if (mi = 'E') i+;if (mi = '-') e = -1;i+;if (mi >= 48 && mi <= 57) do d = mi - 48;p = p * 10 + d;i+; while (mi >= 48 && mi <= 57);if (j > 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.out.println("您输入有误!"); else if (mi = '+') i+;if (mi >= 48 && mi <= 57) do d = mi - 48;p = p * 10 + d;i+; while (mi >= 48 && mi <= 57);if (j > 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.out.println("您输入有误!"); else if (mi >= 48 && mi <= 57) do d = mi - 48;p = p * 10 + d;i+; while (mi >= 48 && mi <= 57);if (j > 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.out.println("您输入有误!"); elseSystem.out.println("您输入有误!");2.实验结果:一、实验目的和要求1 培养学生初步掌握编译原理实验的技能。2 验证所学理论、巩固所学知识并加深理解。3 对学生进行实验研究的基本训练。二、实验内容和原理实验二、 逆波兰式生成程序 内容:掌握语法分析的基本思想,并用高级语言编写逆波兰式生成程序(4学时) 要求:利用逆波兰式生成算法编写程序,将从键盘上输入的算术表达式(中缀表达式)转化成逆波兰式。逆波兰表达式的生成过程涉及到运算符的优先级,下表中列出几个常用运算符的优先关系。如表所示的优先关系矩阵表示了+,-,*,/,(,)等七种运算符之间的相互优先关系。“、”三种符号分别代表“大于”、“小于”、“相等”三种优先关系。左边的“”与右边的“(”之间没有优先关系存在,所以表中为空白。逆波兰表达式生成算法的关键在于比较当前运算符与栈顶运算符的优先关系,若当前运算符的优先级高于栈顶运算符,则当前运算符入栈,若当前运算符的优先级低于栈顶运算符,则栈顶运算符退栈。下面给出了逆波兰表达式生成算法的流程图。(为了便于比较相邻运算符的优先级,需要设立一个工作栈,用来存放暂时不能处理的运算符,所以又称运算符栈)。常用运算符优先关系矩阵 右关系左+-*/()+-*/()三、主要仪器设备PC机+Java语言编程环境四、实验结果与分析1.实验内容: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();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 <= str.length() if (mi = ' ') if (nj = ' ') System.out.println("n"+"结束!");System.exit(0); else do if (nj != '('&&nj != ')')System.out.print( nj);nj = ' 'if (j >= 1)j-; while (nj != ' ');j = j + 1; else if (isOperator(mi) while (isOperator(mi) if (nj = ' ') nj = mi;i+; else if (priority(nj,mi ) = '<') j+;nj = mi;i+; else if (mi = ')') while (j > 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 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;case ')':b = 5;break;return operatorPriorMatrixab;public static boolean isOperator(char operator) if (operator = '+' | operator = '-' | operator = '*'| operator = '/' | operator = '(' | operator = ')')return true;elsereturn false;2.实验结果:-第 14 页-

    注意事项

    本文(太原理工大学编译原理实验(13页).doc)为本站会员(1595****071)主动上传,淘文阁 - 分享文档赚钱的网站仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知淘文阁 - 分享文档赚钱的网站(点击联系客服),我们立即给予删除!

    温馨提示:如果因为网速或其他原因下载失败请重新下载,重复下载不扣分。




    关于淘文阁 - 版权申诉 - 用户使用规则 - 积分规则 - 联系我们

    本站为文档C TO C交易模式,本站只提供存储空间、用户上传的文档直接被用户下载,本站只是中间服务平台,本站所有文档下载所得的收益归上传人(含作者)所有。本站仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。若文档所含内容侵犯了您的版权或隐私,请立即通知淘文阁网,我们立即给予删除!客服QQ:136780468 微信:18945177775 电话:18904686070

    工信部备案号:黑ICP备15003705号 © 2020-2023 www.taowenge.com 淘文阁 

    收起
    展开