递归下降算法_递归下降分析程序得到的经验

递归下降算法_递归下降分析程序得到的经验递归下降算法算法模型:Term=Term+ExprExpr=Expr+FactorFactor=单个元素。最小单位。 实现原理:一个程式进入算法及被看作是一个项,分解成项加表达式的形式,表达式被分解成表达式加因子的形式,因子是这个算法中的最小单位。上一级调用比自己小一级的自己。这里三层分离,越下层模型中所形成的优先级就会越高。 我用递归下降算法写了个简单的计算器,递归算法为我的运算符号…

大家好,又见面了,我是你们的朋友全栈君。

递归下降算法

算法模型:

Term = Term + Expr

Expr=Expr+Factor

Factor =单个元素。最小单位。

 

实现原理:

一个程式进入算法及被看作是一个项,分解成项加表达式的形式,表达式被分解成 表达式加因子的形式,因子是这个算法中的最小单位。

上一级调用比自己小一级的自己。这里三层分离,越下层模型中所形成的优先级就会越高。

 

我用递归下降算法写了个简单的计算器,递归算法为我的运算符号+ – * / 等基础运算符号形成优先级。在使用的过程中发现了递归下降算法很容易产生的一个问题,左递归问题。接下来详细描述这个问题,以及解决方案。

 

什么叫左递归?

举个例子:1-2+1  正确答案应该是0,如果出现左递归答案将会是-2

所谓的左递归其实就是算式在进行同等级运算符的运算的时候强行从右至左进行了运算解析,因为递归下降法中越是后生成的运算符其优先级越高,在同等级运算中,就无法确保优先级了,在这里的体现就是算式从右至左进行了解析。

简单点说,就是虽然是应该为相同优先级的东西,因为生成的先后顺序让它从右至左残生了优先级。

左递归很容易被忽略掉,不测试特定会出BUG的算式,这个BUG是不会出现的,整个程序看上去是在完美运行,毫无破绽。但是实际上整个算式的计算顺序都出现了问题。

 

解决左递归的方案:

解决左递归无非就是解决算式的解析方式,让算式从左自右解析,但是依然能正确的形成符号的优先级就好了。

 

物理模型图对比:

左递归的时候生成的Node

     递归下降算法_递归下降分析程序得到的经验

 

算式1-2+4,越是后面生成的优先级就会高于前面生成的,所以左递归,会先计算2+4。从而导致错误。

 

解决方案:

将运算符号抽象出来单独成立一层,将数值节点统统存入Vector,这样的话,在实际生成到内存中需要判断优先级的只有+ – * / 四个了,因为递归下降算法,所以只要让 * /+ –的下一级子类中生成,就可以确保他们的优先级是正确的。

物理模型如下:

 递归下降算法_递归下降分析程序得到的经验

 

这样就用编程的手法解决了符号的优先级问题,当然也可以通过算法的优化来解决这系列问题,哈哈~!我不会。。。。

 

在来说明下这个解决方案:

内存中只new+ – * / 四个运算符号,NumberNode统统存入到Vector当中,在调用STL算法将NumberNode依次取出,计算就可以了。

 

思路是这个思路,实现代码以后更新。

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/124827.html原文链接:https://javaforall.net

(0)
上一篇 2022年4月20日 上午6:00
下一篇 2022年4月20日 上午6:00


相关推荐

  • Python之json文件

    json简介json是一种轻量级的数据交换格式完全独立于编程语言的文本格式来存储和表示数据简单和清晰的层次结构使得json成为理想的数据交换语言。易于阅读和编写,易于机器解析和生成,并有效地提升

    2021年12月19日
    55
  • adventureworksdw2012_示例数据库怎么导入

    adventureworksdw2012_示例数据库怎么导入1、http://sqlserversamples.codeplex.com/通过网站下载示例数据库,http://msftdbprodsamples.codeplex.com/releases/view/55926 为下载地址2、其中安装AdventureWorks2008R2(oltp)的时候,需要开启sqlserver的filestream功能。点击计算机-管理-右

    2025年11月1日
    5
  • 如何用百度DuClaw在1天内搭建智能报销AI助理

    如何用百度DuClaw在1天内搭建智能报销AI助理

    2026年3月16日
    2
  • AI“养龙虾”,这事靠谱吗?

    AI“养龙虾”,这事靠谱吗?

    2026年3月14日
    1
  • python3 selenium ActionChains用法

    python3 selenium ActionChains用法下面介绍一下 ActionChains 用 selenium 做自动化 有时候会遇到需要模拟鼠标操作才能进行的情况 比如单击 双击 点击鼠标右键 拖拽等等 而 selenium 给我们提供了一个类来处理这类事件 ActionChains nbsp nbsp nbsp selenium webdriver common action chains ActionChains driver 这个类基本能够满足我们所有对鼠标

    2025年11月8日
    4
  • Java实习入职华为,半年后我跑路了

    Java实习入职华为,半年后我跑路了0前言全是干货的技术殿堂文章收录在我的GitHub仓库,欢迎Star/fork:Java-Interview-Tutorialhttps://github.com/Wasabi1234/Java-Interview-Tutorial1何来?我,一个双非本科渣渣,有幸在19届的秋招中得到前东家华为(以下简称hw)的赏识,当时秋招签订就业协议,当时18年10月签订三方后Hr通知说是入了某java部门,之后一系列组织架构调整原因等等让人无法理解的骚操作,最终在毕业前夕的五

    2022年5月15日
    53

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号