从lexyacc奖嘁肫.pdfVIP

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
从lexyacc奖嘁肫

从lexyacc 说到编译器 前言 文法分析中最重要算法是LL 自顶向下和LR 自底向上算法.前面几篇文章主要讲解的是 LL 算法的理论和一个LL 算法的文法分析器javacc.本文以LL(1)算法中最简单的一种形式 递归下降算法来分析常规算法问题中的数学表达式问题.同时,本文也介绍手工构造EBNF 文 法的分析器代码普遍方法.希望本文的实践能对大家实现自己的语法分析器带来帮助. 数学表达式问题 在学习算法的时候,四则混合运算的表达式处理是个很经典的算法问题. 比如这里有个数学表达式¡ 122+2*(11-1)/(3- (2-0))¡ .我们需要根据这个字符串的描述, 然后计算出其结果. Input: 122+2*(11-1)/(3- (2-0)) Output: 142 四则混合运算中还需要考虑到括号,乘除号与加减号的优先运算问题,通常的解决办法就是 使用堆栈.那种常规的算法和LL 算法有异曲同工之处,更或者说,那么的算法其实是一样的. 传统数学表达式处理算法简介 这个传统算法其实不知不觉地使用LL(1)算法的精髓.它就是主要依靠栈式的数据结构 分别保存数和符号,然后根据运算符号的优先级别进行数学计算,并将结果保存在栈里面. 传统算法中使用了两个栈.一个是保存数值,暂时就叫值栈. 另一个是保存符号的,叫符号栈. 我们规定一个记号#,来表示栈底.下面我们就来看看如何计算一个简单的表达式 11+2-8*(5-3). 为了显示整个计算过程,我们以下面这个栈的变化图来表示. 符号栈和值栈的变化是根据输入串来进行的.基本上栈的操作可以简单用下面几句话 来说. Start: 1. 如果当前输入串中得到的是数字,则直接压入值栈.然后转到Start. 2. 如果当前输入串中得到的是符号,那么对符号进行判断. 1)如果符号是¡ +¡ 或者¡ -¡ ,则依次弹出符号栈的符号,计算栈中数值,直到弹出的符号不 是*,/,+,-. 2)如果符号是¡ *¡ 或者¡ /¡ ,则压入符号栈 3)如果符号是¡ (¡ ,则直接压¡ (¡ 入符号栈 4)如果符号是¡ )¡ ,则依照符号栈的顺序弹出符号,计算栈中数值,把结果压入值栈,直到符 号栈顶是¡ (¡ ,最后再弹出¡ (¡ . 最后转到Start. 3. 如果当前输入串得到的是EOF(字符串结束符号),则计算栈中数值,知道符号栈没有符 号. Created with novaPDF Printer (www.novaPDF.com). Please register to remove this message. 语法分析数学表达式 或者可能你以前运用过自己的办法来解决过这个程序问题,不过下面我们将通过编译原 理建立的一套文法分析理论,来十分精彩地解决这个算法问题. 首先是建立数学表达式的文法EBNF.EBNF 文法可以更灵活地表示BNF,是BNF 范式文法的 一种扩展.下面是上一篇javacc 的介绍中使用到的计算表达式的文法. Expression - Term { Addop Term } Addop - + | - Term - Factor { Mulop Factor } Mulop - * | / Factor - ID | NUM | ( Expression )

文档评论(0)

skvdnd51 + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档