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

递归下降算法_递归下降分析程序得到的经验递归下降算法算法模型: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)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • vue取消eslint_webstorm关闭eslint

    vue取消eslint_webstorm关闭eslint在vue项目中新建一个vue.config.js文件打开这个文件,输入module.exports={lintOnSave:false}完成记得保存文件(ctrl+s),在终端中关闭项目,再重启项目(npmrunserve)

    2022年10月8日
    0
  • 如何制作404页面

    如何制作404页面第一步:选取你喜欢的404页面,右键查看源代码,全选复制。第二步:粘贴刚才复制的代码到编辑器,更改对应的跳转链接,文字,以及页面的标题,404图片路径。查看修改编码方式,如不修改可能出现乱码,命名为404.html。第三步:制作404图片,将图片保存到桌面。第四步:打开404.html,没有问题后上传到网站根目录,图片上传到对应的图片路径第五步:在主机管理后台-基础环境设置…

    2022年7月27日
    3
  • leetcode 回溯算法_leetcode有效的括号

    leetcode 回溯算法_leetcode有效的括号原题链接数字 n 代表生成括号的对数,请你设计一个函数,用于能够生成所有可能的并且 有效的 括号组合。示例 1:输入:n = 3输出:[“((()))”,”(()())”,”(())()”,”()(())”,”()()()”]示例 2:输入:n = 1输出:[“()”] 提示:1 <= n <= 8题解回溯class Solution {public: vector<string>res; string t = “”; voi

    2022年8月9日
    3
  • Android Studio 中Intel HAXM安装与模拟器创建「建议收藏」

    Android Studio 中Intel HAXM安装与模拟器创建「建议收藏」AndroidStudio中IntelHAXM安装与模拟器创建

    2022年4月19日
    35
  • jsonArray转jsonObject

    jsonArray转jsonObjectJSONArrayjsonarray=JSONArray.fromObject(actinfo);              for(inti=0;ijsonarray.size();i++){                   JSONObjectob =(JSONObject)jsonarray.get(i);    

    2022年6月7日
    53
  • 详解java中静态方法有哪些_java类中的静态变量

    详解java中静态方法有哪些_java类中的静态变量定义:在类中使用static修饰的静态方法会随着类的定义而被分配和装载入内存中;而非静态方法属于对象的具体实例,只有在类的对象创建时在对象的内存中才有这个方法的代码段。注意:非静态方法既可以访问静态数据成员又可以访问非静态数据成员,而静态方法只能访问静态数据成员;非静态方法既可以访问静态方法又可以访问非静态方法,而静态方法只能访问静态数据方法。原因:因为静态方法和静态数据成员会随着类…

    2022年10月24日
    0

发表回复

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

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