- 1、本文档共6页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
编译实验二 算术表达式解释器
实验二 算数表达式解释器的设计与实现
实验目的
了解并掌握自顶向下语法分析的思想,熟悉递归下降子程序分析法。
了解并掌握语法制导翻译法,掌握采用递归子程序进行语义分析的方法。
实验内容
用适当的程序设计语言编制一个算术表达式的解释器,并完成相应的调试,要求该程序能够读入一个算术表达式,运行后给出计算的结果。
1.算术表达式的解释过程(参考)
第一步:首先进行词法分析(即使用实验一编制的词法分析器),提取最终得到的结果——单词符号序列,将其作为语法和语义分析的输入;
第二步:调用算术表达式的语法及语义分析器。本次实验要求采用递归下降子程序法编写语法分析器,其中要包含对语义的分析。
分析结束后,显示表达式的计算结果。
2.使用的文法
E – TE’
E’ – +TE’ |(
T – FT’
T’ – *FT’|(
F→i|(E)
其中i为整数(最简单的情况),如果考虑周全的话,i可取实数类型(需要看一下自己编制的词法分析器是否对实数进行了识别)。该文法的递归下降子程序见书中74页。
3. 有能力的同学在完成加乘算术表达式的计算后,试扩充文法,增加识别减法和除法的规则,并修改对应的程序,使之能够识别并计算加减乘除四则运算式。
实验要求
1. 程序完成后,由实验老师检查代码,验证程序的功能。如:
输入 (2+3)*10
对文法进行扩充的,输入 (12-8)*20/5+4
等等。
2. 实验二共4学时,实验完成后,提交一份实验报告,写清实验的类型、目的、内容、思路、设计及实现的过程(包括关键的代码,不宜多),以及实验的结果。实验类型为设计型实验。
实验代码
using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.Data;
using System.Drawing;
using System.Linq;
using System.Text;
using System.Windows.Forms;
namespace WindowsFormsApplication5
{
public partial class Form1 : Form
{
public Form1()
{
InitializeComponent();
}
private void button1_Click(object sender, EventArgs e)
{
string str = textBox1.Text;
int sum= Calculate(str);
textBox2.Text = Convert.ToString(sum);
}
public int Calculate(string Expression)
{
Listint numList = new Listint();//数字列表
Listchar OperatorList = new Listchar();//运行符列表 bool numState = true;//true:刚遇到符号 int num = 0;
Expression = getExpressionNoBrackets(Expression);//读取括号情况 char[] expression = Expression.ToCharArray();
for (int i = 0; i expression.Length; i++)
{
if(Convert.ToInt16(expression[i])58||Convert.ToInt16(expression[i]) 48)
{
switch (expression[i])
{
case +:
numState = true;
nu
您可能关注的文档
- 3dsmax教学课程-基础.ppt
- 07+NX6曲线.ppt
- 第三章_反求工程.ppt
- 1、建模 ——UG的简介草图模块介绍 绘制.ppt
- 动画部分 第五章 基础动画.ppt
- 3DMAX第六讲.ppt
- 129180488577718748曲线曲面建模1.ppt
- mastercam课件第二章.ppt
- AutoCAD讲义14.pptx
- 第4章 简单的二维图形.ppt
- 1.“钓鱼”游戏_课件 人教鄂教版(2024)科学一年级上册.pptx
- 20 生物进化的证据 课件 粤教粤科版科学六年级上册.pptx
- 第1课 我的名字 课件 人教版(2024新版)一年级上册美术.pptx
- 人教版美术 一年级上册 第一单元 4 灵动的龙 课时教案.doc
- 3.怎样学科学(第1课时)_课件 人教鄂教版(2024)科学一年级上册.pptx
- 17 生物的遗传现象 课件 粤教粤科版科学六年级上册.pptx
- 人教版(新起点)五上 Unit 3 Animals Period 3 Animals different children like第三课时课件.pptx
- 3.2.3 8和9的加减法 教学设计 2024新人教版数学一年级上册.pptx
- 15 大脑的作用 课件 粤教粤科版科学六年级上册.pptx
- 第5课 中秋月儿圆 教案 人教版(2024新版)一年级上册美术.docx
文档评论(0)