C 四则运算表达式解析器
下载实例:http://www.wisdomdd.cn/Wisdom/resource/articleDetail.htm?resourceId=1074
程序主要包括:基础结构定义、词法分析、语法分析、算术运算
基础结构定义:枚举(操作数类型、操作符类型、标记类型、有限状态自动机);
结构(操作数、操作符、标记、标记链)。
词法分析:将字符串分解成有效标记(有效的操作数和操作符),生成标记链表。
语法分析:分析括弧的有效性,操作数、操作符的排列有效性,操作符与操作数类型匹配关系。
算术运算:使用后缀表达式运算规则,根据后缀表达式链表进行求值。首先将我们日常应用的中缀表达式转换为后缀表达式。例如:6*(5-3) 转换为 6 5 3 - *,6-2+5*2转换为 6 2 - 5 2 * +
这里对后缀表达式的转换作一个说明,每个操作符有一个运算优先级(oper_PRI),但是当表达式中含有括弧时,括弧中的操作符运算优先级会改变。所以增设了一个括弧深度优先级(deep_PRI)。采用两个优先级的方式比使用栈显得简单易读。
操作符 | oper_PRI |
+ | 7 |
- | 7 |
* | 9 |
在转换时,操作符拥有两个优先级,表示为:操作符(deep_PRI,oper_PRI)
依次输入表达式 5+(8-2*3)*4 的各个标记 最后输出5 8 2 3 * - 4 * +。
输入 | 临时空间
输入操作符时,放入临时空 间,同时触发动作。 操作符(deep_PRI,oper_PRI) 初始 deep_PRI=0 |
动作
输入’(’时,deep_PRI++ 输入’)’时,deep_PRI-- 输入操作符时,上一个操作符与其比较 优先级,为true,则输出上一操作符。 比较规则: deep_PRI > deep_PRI || (deep_PRI == deep_PRI && oper_PRI >= oper_PRI) |
输出
操作数直接 输出 |
5 | 5 | ||
+ | +(0,7) | ||
( | +(0,7) | deep_PRI++ | |
8 | +(0,7) | 8 | |
- | +(0,7)
-(1,7) |
+(0,7)与 -(1,7)比较
0>1||(0==1&&7>=7) 为false 不输出 |
|
2 | +(0,7)
-(1,7) |
2 | |
* | +(0,7)
-(1,7) *(1,9) |
-(1,7)与 *(1,9)比较
1>1||(1==1&&7>=9) 为false 不输出 |
|
3 | +(0,7)
-(1,7) *(1,9) |
3 | |
) | +(0,7)
-(1,7) *(1,9) |
deep_PRI-- | |
* | +(0,7)
-(1,7) *(1,9) *(0,9) |
*(1,9)与 *(0,9)比较
1>0||(1==0&&9>=9) 为true 输出*(1,9) |
* |
+(0,7)
-(1,7) *(0,9) |
-(1,7)与 *(0,9)比较
1>0||(1==0&&7>=9)为true 输出-(1,7) |
- | |
+(0,7)
*(0,9) |
+(0,7)与 *(0,9)比较
0>0||(0==0&&7>=9) 为false 不输出 |
||
4 | +(0,7)
*(0,9) |
4 | |
+(0,7)
*(0,9) |
没有操作符:倒序输出临时空间值 | * | |
+(0,7) | + |
C 四则运算表达式解析器的更多相关文章
- java字符串应用之表达式解析器
一.表达式的组成 1.数字 2.运算符:+ - / * ^ % = 3.圆括号 4.变量二.运算符优先级 由高到低分别为:+-(正负号).^.*/%.+-.= 优先 ...
- [LeetCode] Ternary Expression Parser 三元表达式解析器
Given a string representing arbitrarily nested ternary expressions, calculate the result of the expr ...
- Anrlr4 生成C++版本的语法解析器
一. 写在前面 我最早是在2005年,首次在实际开发中实现语法解析器,当时调研了Yacc&Lex,觉得风格不是太好,关键当时yacc对多线程也支持的不太好,接着就又学习了Bison&F ...
- spring中EL解析器的使用
SpEL对表达式语法解析过程进行了很高的抽象,抽象出解析器.表达式.解析上下文.估值(Evaluate)上下文等对象,非常优雅的表达了解析逻辑.主要的对象如下: 类名 说明 ExpressionPar ...
- SpringEl表达式解析
应用场景: 1.用户日志 2.缓存处理 3........... import org.springframework.expression.EvaluationContext; import org ...
- Spring 缓存注解 SpEL 表达式解析
缓存注解上 key.condition.unless 等 SpEL 表达式的解析 SpEl 支持的计算变量: 1)#ai.#pi.#命名参数[i 表示参数下标,从 0 开始] 2)#result:Ca ...
- SPEL 表达式解析
Spring Expression Language 解析器 SPEL解析过程 使用 ExpressionParser 基于 ParserContext 将字符串解析为 Expression, Exp ...
- Spring 源码(5)BeanFactory使用的准备及自定义属性值解析器
BeanFactory 使用前的准备 上一篇文章 https://www.cnblogs.com/redwinter/p/16165878.html 介绍了自定义标签的使用,完成了AbstractAp ...
- 用java实现编译器-算术表达式及其语法解析器的实现
大家在参考本节时,请先阅读以下博文,进行预热: http://blog.csdn.net/tyler_download/article/details/50708807 本节代码下载地址: http: ...
随机推荐
- Unity UGUI基础之Slider、Scrollbar
Slider(滑动条):是一个主要用于形象的拖动以改变目标值的控件,他的最恰当应用是用来改变一个数值,最大值和最小值自定义,拖动滑块可在此之间改变,例如改变声音大小. Scrollbar(滚动条):是 ...
- 为什么不要重载 && 和 || 操作符!!!
理论知识: 1)&&和 || 是C++中非常特殊的操作符 2)&&和 || 内置实现了短路规则 简单说明一下短路规则. demo1 #include <iostr ...
- cocos2d-js(二)cocos2d-js的基本语法与类的简介
基本语法: 1.类的定义 一般类都是集成Scene或者Layer: var myLayer = cc.Layer.extend({类的内容}); 2类内的成员变量与方法: 2.1成员变量的声明: 变量 ...
- java设计模式---职责链模式
职责链的本质:分离职责,动态组合 样例: /** * 定义职责对象的接口 * */ public abstract class Handler { protected Handler successo ...
- 小强的HTML5移动开发之路(16)——神奇的拖放功能
来自:http://blog.csdn.net/dawanganban/article/details/18181273 在智能手机发展飞速的现在拖放功能已经成为一种时尚,但是在我们的浏览器上是不是还 ...
- AngularJS进阶(三十一)AngularJS项目开发技巧之获取模态对话框中的组件ID
AngularJS项目开发技巧之获取模态对话框中的组件ID 需求 出于项目开发需求,需要实现的业务逻辑是:药店端点击查看"已发货""已收货"订单详情时,模块弹出 ...
- 《java入门第一季》之面向对象(抽象类到底多抽象)
/* 抽象类的概述: 动物不应该定义为具体的东西,而且动物中的吃,睡等也不应该是具体的. 我们把一个不是具体的功能称为抽象的功能,而一个类中如果有抽象的功能,该类必须被称为是抽象类. 抽象类的特点: ...
- mysql进阶(十九)SQL语句如何精准查找某一时间段的数据
SQL语句如何精准查找某一时间段的数据 在项目开发过程中,自己需要查询出一定时间段内的交易.故需要在sql查询语句中加入日期时间要素,sql语句如何实现? SELECT * FROM lmapp.lm ...
- Android开源项目——带图标文字的底部导航栏IconTabPageIndicator
接下来的博客计划是,在<Android官方技术文档翻译>之间会发一些Android开源项目的介绍,直接剩下的几篇Android技术文档发完,然后就是Android开源项目和Gradle翻译 ...
- 01_Nginx安装,nginx下部署项目,nginx.conf配置文件修改,相关文件配置
1.下载Nginx,进入Nginx下载地址:http://nginx.org/ 点击nginx-1.8.0,进入:http://nginx.org/en/download.html,下载文件: ...