太原理工 编译原理 c语言,太原理工大学编译原理实验

《太原理工大学编译原理实验》由会员分享,可在线阅读,更多相关《太原理工大学编译原理实验(19页珍藏版)》请在人人文库网上搜索。

1、本科实验报告课程名称: 编译原理 实验项目:无符号数的词法分析程序(实验一)实验地点: 计算机学院软件实验室 专业班级: 学号: 学生姓名: 指导教师: 冯秀芳 2013年 11 月16日一、实验目的和要求1 培养学生初步掌握编译原理实验的技能。2 验证所学理论、巩固所学知识并加深理解。3 对学生进行实验研究的基本训练。二、实验内容和原理实验一、 无符号数的词法分析程序(4学时)内容:掌握词法分析的基本思想,并用高级语言编写无符号数的词法分析程序。要求:从键盘上输入一串字符(包括字母、数字等),最后以“;”结束,编写程序识别出其中的无符号数。无符号数文法规则可定义如下:.EE +-0 1 2 。

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。

3、, 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 57) i+; else do d = mi - 48;w = w * 10 + d;j+;i+; while (mi = 48 & mi = 48 & mi = 48 & mi 1)w2 = w / (Mat。

4、h.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 - 1);System.out.println(实型数为: + w2 + *10 + + (e * (p + j - 1);j = 0;w2 = 0;w = 0;p = 0; el。

5、seSystem.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(您输入有误!);else i+;if (mi = 48 & mi = 48 & mi = 48 & mi = 48 & mi 1) w2 = w / (Math.pow(10.0, j - 1);。

6、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 = 48 & mi 1) w2 = w / (Math.pow(10.。

7、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 = 48 & mi 1) w2 = w / (Math.pow(10.0, j 。

8、- 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.实验结果:本科实验报告课程名称: 编译原理 实验项目: 基本程序设计。

9、(实验二) 实验地点: 计算机学院606实验室 专业班级: 计Z1101 学号:学生姓名: 李康达 指导教师: 段利国 2013年 11 月23日一、实验目的和要求1 培养学生初步掌握编译原理实验的技能。2 验证所学理论、巩固所学知识并加深理解。3 对学生进行实验研究的基本训练。二、实验内容和原理实验二、 逆波兰式生成程序内容:掌握语法分析的基本思想,并用高级语言编写逆波兰式生成程序(4学时)要求:利用逆波兰式生成算法编写程序,将从键盘上输入的算术表达式(中缀表达式)转化成逆波兰式。逆波兰表达式的生成过程涉及到运算符的优先级,下表中列出几个常用运算符的优先关系。常用运算符优先关系矩阵右关系左+。

10、-*/()+-*/()如上表所示的优先关系矩阵表示了+,-,*,/,(,)等七种运算符之间的相互优先关系。“、”三种符号分别代表“大于”、“小于”、“相等”三种优先关系。左边的“”与右边的“(”之间没有优先关系存在,所以表中为空白。逆波兰表达式生成算法的关键在于比较当前运算符与栈顶运算符的优先关系,若当前运算符的优先级高于栈顶运算符,则当前运算符入栈,若当前运算符的优先级低于栈顶运算符,则栈顶运算符退栈。下面给出了逆波兰表达式生成算法的流程图。(为了便于比较相邻运算符的优先级,需要设立一个工作栈,用来存放暂时不能处理的运算符,所以又称运算符栈)。三、主要仪器设备PC机+Java语言编程环境四、。

11、实验结果与分析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.。

12、readLine();char m = new char20;for (int o = 0; o = 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 = ;。

13、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;cas。

14、e -: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.实验结果。

  • 0
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值