与/或表达式化简

2016-01-29 12:14 60 1 收藏

与/或表达式化简,与/或表达式化简

【 tulaoshi.com - C语言心得技巧 】

与/或表达式化简

作者:袁国桃 (西安理工大学 计算机学院)

(本文来源于图老师网站,更多请访问https://www.tulaoshi.com)
源代码下载

  我在VCKBASE里面混了已有两年多的时间了。在这期间我看到了许多优秀了技术文档,我从中受益非浅。一直想为她写些什么,但总是感到心有余而力不足。现在我已经是大四学生,还有十几天就要离开校园了。在这大学的最后时刻,我决定为VCKBASE写些什么新鲜的东西来各大家分享一下。碰巧我在做毕业设计的时候,有个同学是做编译器的词法分析的,我在VCKBASE《在线杂志》第二十六期上也看到过ZF.Yi写的一篇关于表达式计算的文档《简单的表达式求值》,很值得我们学习。因此,我就决定写一篇类似的文档来和大家共同探讨和学习。

一、问题的提出

  假如我们有如下所示的与/或表达式:
      a*[b*[c+d]*e+f]+g
化简后要得到如下的表达式:
      a*b*c*e+a*b*d*e+a*f+g  
表达式中允许的字母和算符
      {A-Z, a-z, [,],*,+}
其中“[,]”表示括号,允许嵌套;“*”表示逻辑运算符“与”;“+”表示逻辑运算符“或”;并且“*”的优先级高于“+”。

二、解决办法

  在编译原理中,有一种自上而下分析方法LL(1),其核心算法就是“递归下降法”,其具体理论有兴趣的朋友可以参考一些编译原理书籍。首先让我们来看一个编译原理课本上用“递归下降法”进行“表达式的求值”的分析得到的产生式:
      exp-exp addop term|term      addop-+|-      term-term mulop factor|factor      mulop-*      factor-(exp)|number      
  其中“exp”代表待求值的表达式;“addop”代表“+”和“-”运算符;“term”代表用“*”连接起来的表达式;“mulop”代表“*”;“factor”代表乘积因子,它可以是一个数,也可以是一个表达式。
  按照这种思路,我得出了如下的对应于本文开头所提出问题的产生式:
      exp-term { OR term }|term      
      OR-+      term-term AND factor|factor      AND-*      factor-[exp]|letter      letter-[A-Z]|[a-z]      
去除左递归后如下所示:
      exp-term { OR term }      OR-+      term-factor { AND factor }       factor-letter|[exp]      AND-*      letter-[A-Z]|[a-z]
  这样,我们就很容易将其转化为代码。比如,将“exp-term { OR term }”这个表达式转化的伪代码如下:
CString exp(){  CString temp = _T("");  try  {    temp = Term();    while( 当前还没有到输入串的末尾 && 下一个将要扫描的字符为OR )    {      temp += "+";      Match(OR);//字符匹配,用户判断将要扫描的字符是否为所期望的字符,并且推动扫描串的前进      temp += Term();    }  }  catch(CError& error)  {    throw error;   }  return temp;}    
其它的产生式对应的代码类似,具体细节就不叙述了,请大家参考参考源程序。

三、运行效果图



四、结束语

  这是我第一次在VCKBASE上发表的文章,其中肯定存在许多不足之处,希望大家指出来批评指正
^-^。同时,我也感觉到深为一名学习计算机的学生,丰富的编程实际经验固然重要,但如果具有丰富的理论基础作为坚强后盾的话,那么我们在编写程序时就会游刃有余,才会感觉到写程序是一种真正的享受^-^。

来源:https://www.tulaoshi.com/n/20160129/1485192.html

延伸阅读
简单的表达式求值 作者/ZF.Yi 下载源代码 一直很想做个比 Windows 自带的高级一点的计算器,能将整个表达式输入,然后求值。这个程序要求读者具备编译原理的一些知识。举个实例来说明程序处理过程。假设要求值的表达式为 : -25*(56+15)# (其中#号作为表达式结束标志)...
标签: Web开发
正则表达式的功能实在太强大了~以下为找到的一个关于正则表达式基本语法的介绍: 首先让我们看两个特殊的符号'^'和'$'。他们的作用是分别指出一个字符串的开始和结束。例子如下: "^The":表示所有以"The"开始的字符串("There","The cat"等); "of despair$":表示所以以"of despair"结尾的字符串; "^abc$":表示开始和结尾都是"abc"...
标签: Web开发
一、正则表达式概述  二、正则表达式在VBScript中的应用  三、正则表达式在VavaScript中的应用  四、示例   一、正则表达式概述  如果原来没有使用过正则表达式,那么可能对这个术语和概念会不太熟悉。不过,它们并不是您想象的那么新奇。  请回想一下在硬盘上是如何查找文件的。您肯定会使用 ? 和 * 字...
标签: Web开发
最后写了一个IP地址的正则表达式验证程序。 代码如下: ((25[0-5]|2[0-4]\d|1?\d?\d)\.){3}(25[0-5]|2[0-4]\d|1?\d?\d) 截图如下:
标签: ASP
       最近很多帖子问如何将内容从数据库取出后换行,这就要用到正则表达式。简单的说,正则表达式是一种可以用于模式匹配和替换的强有力的工具。我们可以在许多编程语言中找到正则表达式的身影,例如,vi编辑器,Perl或PHP脚本语言,以及awk或sed shell程序等。此外,象JavaScript这种客户端的脚本语言也...

经验教程

913

收藏

51
微博分享 QQ分享 QQ空间 手机页面 收藏网站 回到头部