当前位置: 首页 > 图文教程 > 开发语言 > VC++ > 简单的表达式求值

VC++
几个数字信号处理算法程序
简易软盘镜像工具的实现及操作系统编写初步
教你使用正则表达式
C++ 扩展和嵌入 Python
拷贝构造和赋值操作符,C#和本机 C++ 代码的互用性
精通VC与Matlab联合编程(六)
精通VC与Matlab联合编程(五)
一个排序用的C++函数模板
浅析VC与MATLAB联合编程
C++编译器如何实现异常处理
文件重定义冲突的分析与解决
一步一步实现MFC扩展DLL中导出类和对话框
C宏:智者的利刃,愚者的恶梦!
引用的作用
《UTF-8与GB2312之间的互换》的改进
程序风格的要素-C++风格指南
VC+6.0实现文本串的自由拆分
怎样给串行化类分配版本号(可配置版本模式)
在常规的编程任务中使用新的 <tuple> 库
使用 typedef 抑制劣质代码

VC++ 中的 简单的表达式求值


出处:互联网   整理: 软晨网(RuanChen.com)   发布: 2009-10-30   浏览: 45 ::
收藏到网摘: n/a

简单的表达式求值


作者/ZF.Yi

下载源代码


一直很想做个比 Windows 自带的高级一点的计算器,能将整个表达式输入,然后求值。这个程序要求读者具备编译原理的一些知识。举个实例来说明程序处理过程。假设要求值的表达式为 :

 -25*(56+15)# (其中#号作为表达式结束标志)。 
首先对表达式进行词法分析,允许出现的字符为:
 {0 ,1, 2 ,3 ,4 ,5 ,6, 7 ,8, 9 . ,+ ,-, *, / ,( ,),#} 
分析的结果产生两种类型的单词:操作符和操作数。

操作符包括:
 {+, - ,* ,/ ,( ,)} 
操作数包括:
 int 和 double 类型。 
上面表达式产生的单词序列为:
 {-25,*,(,56,+,15,)}。 
这些单词的类型也需要保存。

词法分析正确后将对产生的单词序列进行语法分析。

定义E为表达式,N为常数(视为终结符)。表达式的产生式可表示如下:
 E ' N E ' (E) E ' E+E E ' E-E E ' E*E E ' E/E
消除左递归后的产生式(E_为新产生的符号):
 E->NE_ E->(E)E_ E_->+EE_ E_->-EE_ E_->*EE_ E_->/EE_ E_->NULL (空串)
可以根据这个产生式构造递归的语法分析器。具体细节就不叙述了,可以阅读源代码。

语法分析正确后就可以求值了,求值时用到一个操作数堆栈和操作符堆栈,以及一个算符优先表(存储了运算符之间的优先关系),具体细节可以阅读源码。