当前位置: 首页 > 编程日记 > 正文

【原创】VB利用堆栈实现算术表达式计算

这个抽象算法早已为人所知,只不过在VB的公开文档中鲜见示例代码。于是,为了提高自己的程序设计水平,锻炼自己的能力,我写了如下代码。

【VB代码版权所有,允许转载修改用作学习目的,转载必须注明来源

【求大家看完后留言啊!】

堆栈类的实现:

 1 Private Stack() As String
 2 Private itemCount As Long
 3 Private Sub Class_Initialize()
 4     ReDim Stack(0)
 5     Stack(0) = "#"
 6 End Sub
 7 Public Sub Push(ByVal inString As String)
 8     ReDim Preserve Stack(itemCount + 1)
 9     Stack(itemCount + 1) = inString
10     itemCount = itemCount + 1
11 End Sub
12 
13 Public Function Pop() As String
14     If itemCount >= 1 Then
15         Pop = Stack(itemCount)
16         ReDim Preserve Stack(itemCount - 1)
17         itemCount = itemCount - 1
18     Else
19         Pop = ""
20     End If
21 End Function
22 Public Function Peek() As String
23     If itemCount = 0 Then
24         Peek = ""
25         Exit Function
26     End If
27     Peek = Stack(itemCount)
28 End Function
29 
30 Sub Clear()
31     itemCount = 0
32     ReDim Stack(itemCount)
33     Stack(itemCount) = "#"
34 End Sub
35 
36 Public Function Count()
37     Count = itemCount
38 End Function
39 Public Function ViewStack() As String
40     Dim kOut As String
41     Dim i As Long
42     If itemCount = 0 Then ViewStack = "": Exit Function
43     For i = 1 To itemCount
44         kOut = kOut & Format(i, "00") & " " & Stack(i) & vbCrLf
45     Next i
46     ViewStack = kOut
47 End Function

计算模块中的代码:

  1 Public opNum As New StackClass
  2 Public opChar As New StackClass
  3 Public Function CalcString(ByVal strIn As String) As String
  4     Dim sTxt As String
  5     Dim strNumFix As String
  6     Dim curChar As String
  7     Dim i As Long
  8     Dim signCount As Long
  9     Dim ops1 As String, ops2 As String, opC As String
 10     '初始化堆栈
 11         opNum.Clear
 12         opChar.Clear
 13     '堆栈初始化结束
 14     sTxt = strIn
 15     For i = 1 To Len(sTxt)
 16         curChar = Mid(sTxt, i, 1)
 17         If IsSymbol(curChar) = True Then
 18             '看看数字预备区有没有
 19             If strNumFix <> "" Then
 20                 opNum.Push strNumFix
 21                 strNumFix = ""
 22             End If
 23 redo:
 24             If IsHigh(curChar, opChar.Peek) = 1 Then 'if new come char is higher then push it to stack
 25                 opChar.Push curChar '如果等级高的控制符,则进入
 26                 signCount = signCount + 1
 27             ElseIf IsHigh(curChar, opChar.Peek) = 0 Then
 28                 If curChar = "#" And opChar.Peek = "#" Then
 29                     opChar.Pop
 30                     CalcString = opNum.Pop
 31                     Exit Function
 32                 End If
 33             ElseIf IsHigh(curChar, opChar.Peek) = -1 Then 'if low then ready to calculate
 34                 '判断是不是第一个符号
 35                 If signCount = 1 Then '这个符号是刚刚输入#后的那个,无论如何入栈
 36                     opChar.Push curChar
 37                     signCount = signCount + 1
 38                     GoTo nextone
 39                 End If
 40                 ops2 = opNum.Pop
 41                 ops1 = opNum.Pop
 42                 opC = opChar.Pop
 43                 opNum.Push CStr(Calc(ops1, ops2, opC))
 44                 If curChar = ")" And opChar.Peek = "(" Then
 45                     opChar.Pop  '如果操作数是),就把(弹出来
 46                     GoTo moveon
 47                 End If
 48                 GoTo redo
 49 moveon:
 50             End If
 51         Else '非符号
 52             strNumFix = strNumFix & curChar
 53         End If
 54 nextone:
 55     Next i
 56 End Function
 57 
 58 Public Function Calc(ByVal op1 As String, ByVal op2 As String, ByVal options As String) As Double
 59 On Error Resume Next
 60 Calc = 0
 61 Select Case options
 62     Case "+"
 63         Calc = CDbl(op1) + CDbl(op2)
 64     Case "-"
 65         Calc = CDbl(op1) - CDbl(op2)
 66     Case "*"
 67         Calc = CDbl(op1) * CDbl(op2)
 68     Case "/"
 69         Calc = CDbl(op1) / CDbl(op2)
 70 End Select
 71 End Function
 72 
 73 Public Function IsHigh(ByVal sNew As String, ByVal sOld As String) As Integer
 74 '1大于,-1小于,0等于
 75 Select Case sNew
 76 Case "+"
 77     Select Case sOld
 78         Case "("
 79             IsHigh = 1
 80             Exit Function
 81         Case "#"
 82             IsHigh = 1
 83             Exit Function
 84         Case Else
 85             IsHigh = -1
 86             Exit Function
 87     End Select
 88 Case "-"
 89     Select Case sOld
 90         Case "("
 91             IsHigh = 1
 92             Exit Function
 93         Case "#"
 94             IsHigh = 1
 95             Exit Function
 96         Case Else
 97             IsHigh = -1
 98             Exit Function
 99     End Select
100 Case "*"
101     Select Case sOld
102         Case "("
103             IsHigh = 1
104             Exit Function
105         Case "#"
106             IsHigh = 1
107             Exit Function
108         Case "+"
109             IsHigh = 1
110             Exit Function
111         Case "-"
112             IsHigh = 1
113             Exit Function
114         Case Else
115             IsHigh = -1
116             Exit Function
117     End Select
118 Case "/"
119     Select Case sOld
120         Case "("
121             IsHigh = 1
122             Exit Function
123         Case "#"
124             IsHigh = 1
125             Exit Function
126         Case "+"
127             IsHigh = 1
128             Exit Function
129         Case "-"
130             IsHigh = 1
131             Exit Function
132         Case Else
133             IsHigh = -1
134             Exit Function
135     End Select
136 Case "("
137     Select Case sOld
138         Case "+"
139             IsHigh = 1
140             Exit Function
141         Case "-"
142             IsHigh = 1
143             Exit Function
144         Case "*"
145             IsHigh = 1
146             Exit Function
147         Case "/"
148             IsHigh = 1
149             Exit Function
150         Case "("
151             IsHigh = 1
152             Exit Function
153         Case Else
154             IsHigh = -1
155             Exit Function
156     End Select
157 Case ")"
158     IsHigh = -1
159     Exit Function
160 Case ""
161     IsHigh = -1
162     Exit Function
163 Case "#"
164     Select Case sOld
165         Case "#"
166             IsHigh = 0
167             Exit Function
168         Case ""
169             IsHigh = 1
170             Exit Function
171         Case "+"
172             IsHigh = -1
173             Exit Function
174         Case "-"
175             IsHigh = -1
176             Exit Function
177         Case "*"
178             IsHigh = -1
179             Exit Function
180         Case "/"
181             IsHigh = -1
182             Exit Function
183         Case ")"
184             IsHigh = -1
185             Exit Function
186     End Select
187 End Select
188 End Function
189 
190 Public Function IsSymbol(ByVal strS As String) As Boolean
191     IsSymbol = True
192     Select Case strS
193         Case "+"
194         Case "-"
195         Case "*"
196         Case "/"
197         Case "("
198         Case ")"
199         Case "#"
200         Case Else
201             IsSymbol = False
202     End Select
203 End Function

转载于:https://www.cnblogs.com/sunsoftresearch/archive/2013/04/23/3037271.html

相关文章:

树莓派4与英伟达Jetson Nano性能大比拼,谁是最佳的嵌入式“电脑”?

作者 | Chris Pietschmann译者 | 弯月&#xff0c;责编 | 屠敏转载自CSDN&#xff08;ID&#xff1a;CSDNnews&#xff09;导读&#xff1a;日前&#xff0c;Raspberry 基金会发布了开发者为之兴奋的 Raspberry Pi 4&#xff0c;其不仅在性能上进行了全面的升级&#xff0c;而且…

作为互联网流量入口,CDN日志大数据你该怎么玩?

CDN是非常重要的互联网基础设施&#xff0c;用户可以通过CDN&#xff0c;快速的访问网络中各种图片&#xff0c;视频等资源。在访问过程中&#xff0c;CDN会产生大量的日志数据&#xff0c;而随着如今越来越复杂的网络环境变化&#xff0c;和业务的迅速增长&#xff0c;日志数据…

OpenCV中图像旋转(warpAffine)算法的实现过程

在OpenCV中&#xff0c;目前并没有现成的函数直接用来实现图像旋转&#xff0c;它是用仿射变换函数cv::warpAffine来实现的&#xff0c;此函数目前支持4种插值算法&#xff0c;最近邻、双线性、双三次、兰索斯插值&#xff0c;如果传进去的参数为基于像素区域关系插值算法(INTE…

10亿美元续命!OpenAI获微软投资,意在通用人工智能?

来源 | OpenAI官博译者 | 孙薇编辑 | 一一出品 | AI科技大本营&#xff08;ID:rgznai100&#xff09; 7 月 22 日&#xff0c;微软宣布将对非营利人工智能研究组织 OpenAI 投资 10 亿美元&#xff0c;用于通用人工智能&#xff08;AGI&#xff09;的开发。双方将以微软原有的公…

TrayIcon 类 添加系统托盘不显示托盘图标

为什么80%的码农都做不了架构师&#xff1f;>>> 好久不碰 java swing最近写了一个swing 程序 添加托盘时&#xff0c;怎么也不显示图标&#xff0c;就一空白 &#xff0c;在网上搜了老半天&#xff0c;大部无效。 边看帖子边看 java api ,结合理解,有一属性设置了一…

Crystal Report 加载模板报错 无法在c++ 堆栈中打开由jrc 引擎处理的文档

2019独角兽企业重金招聘Python工程师标准>>> 纠结了很久, 尝试过录入一个错误的路径,文件读取也是包相同的错误,也就是表示找不到路径文件而已,并不是开发环境的问题 于是设置一个最简单的路径,放置下去rpt模板,代码后续没有报错; 再次之前也修复了一个关于引用的dl…

Ubuntu下makefile及gcc生成静态库动态库的简单使用举例

环境&#xff1a;Ubuntu-13.10 32位(虚拟机)、gcc4.8.1 首先创建一个test_makefile_gcc文件夹&#xff0c;此test_makefile_gcc文件夹下包括&#xff1a;src文件夹用于存放源文件&#xff1b; include文件夹用于存放头文件&#xff1b;bin文件夹用于存放生成的动态库.so文件&…

Exchange Server 2013 安装完成后配置外部URL

Exchange Server 2013 安装完成后配置外部URL 比如 mail.contoso.com 1、转到 EAC → “服务器”&#xff0c;然后单击“配置外部访问域”。2、在“选择要与外部 URL 一起使用的客户端访问服务器”下面&#xff0c;单击“添加”3、选择您要配置的客户端访问服务器&#xff0c;…

Ubuntu下CodeBlocks的安装、配置及静态库动态库的简单使用举例

1、 从Ubuntu Software Center中搜索Code::Blocks并安装&#xff1b; 2、 在第一次启动时选择GNU GCC Compiler作为默认的编译器&#xff1b; 3、 生成静态库并调用操作步骤&#xff0c;代码同 http://blog.csdn.net/fengbingchun/article/details/17994489 3.1、New fil…

React 打怪笔记

介绍 本文为学习react中的记录。 Tips: 当组件的props或state有变化&#xff0c;执行render函数。无论是使用函数或是类来声明一个组件&#xff0c;它决不能修改它自己的propsReact 可以将多个setState() 调用合并成一个调用来提高性能。无状态函数式组件 (stateless functiona…

新闻智能分类练习赛开始报名啦!最先达到80分就可以领GPU,技术书籍!

现代信息爆炸般地产生&#xff0c;信息如海如潮。信息分类&#xff0c;不仅有利于加快信息检索速度&#xff0c;且有利于提高查准率。Internet是信息的重要载体&#xff0c;深入地研究与探讨网上信息自动分类的方法、技术和理论&#xff0c;已成为时代的迫切需求和新的研究热点…

项目经理应该具备的技能

作为一个优秀的项目经理应该具备五个方面的技能: 项目管理知识体系 应用领域的相关知识、标准和规则项目环境知识一般管理知识软技能/人际关系技能项目管理知识体系 就是要掌握常说的9大知识领域&#xff1a;范围、时间、成本、质量、人力资源、风险、沟通、采购再加上集成…

SSE2 Intrinsics各函数介绍

SIMD相关头文件包括&#xff1a; //#include <ivec.h>//MMX//#include <fvec.h>//SSE(also include ivec.h)//#include <dvec.h>//SSE2(also include fvec.h)#include <mmintrin.h> //MMX#include <xmmintrin.h> //SSE(include mmintrin.h)#incl…

中国城市道路名图鉴

作者| AlfredWu来源 | Alfred数据室&#xff08;ID&#xff1a;Alfred_Lab&#xff09;不知道大家出差或旅游的时候有没有发现&#xff0c;有些城市特别喜欢使用其它城市或者省份的名字作为道路名&#xff0c;特别是青岛市&#xff0c;这会儿还在徐州路&#xff0c;走过一个街区…

中国电子信息产业发展研究院主办的2018中国软件大会上大快搜索“又双叒叕”获奖了...

大快搜索自荣获“2018中国大数据企业50强”殊荣&#xff0c;12月20日在由工信部指导&#xff0c;中国电子信息产业化发展研究院主办的2018中国软件大会上&#xff0c;大快搜索获评“2018中国大数据基础软件领域领军企业”称号&#xff0c;入选中国数字化转型TOP100服务商&#…

SystemCenter2012SP1实践(15)共享库服务器和ISO

用过HyperV的同学都知道&#xff0c;HyperV调用ISO作为启动光盘的时候&#xff0c;必须保存在本地才行。网络共享下的一概不认。在SCVMM下&#xff0c;我们可以通过一些设置&#xff0c;让SCVMM下创建的虚拟机&#xff0c;支持调用不在同一台主机上的ISO文件。我是分隔线首先要…

XLNet:公平PK,BERT你已经被超过!

作者 | XLNet Team译者 | 孙薇责编 | Jane出品 | AI科技大本营&#xff08;ID: rgznai100&#xff09;【导语】几周前&#xff0c;XLNet 团队发布了新型预训练语言模型 XLNet&#xff0c;这个新模型在各项基准测试中都优于谷歌之前发布的BERT模型&#xff0c;其中模型 XLNet-La…

C/C++中switch用法的一种替换方式

在C/C中&#xff0c;switch语句是经常被用到的&#xff0c;当switch内的case语句较多时程序有时显得比较繁乱&#xff0c;此种情况下可以用另外一种实现方式替代switch。详细用法见例子&#xff1a; #include "stdafx.h"float AddFunc(float a, float b) {return (a …

My excellent 2018

又到一年年底时&#xff0c;除了感叹一句时间过得真快之外&#xff0c;也非常庆幸自己能够渡过了这精彩的一年。 工作 首先是工作上面的变化。自16年毕业以后就在招联消费金融有限公司上班&#xff0c;一直到今年的五月份。在招联的期间&#xff0c;有幸得到老大的赏识&#xf…

POJ 2955 Brackets (区间DP)

题目链接&#xff1a;http://poj.org/problem?id2955 BracketsTime Limit: 1000MS Memory Limit: 65536KTotal Submissions: 1977 Accepted: 1012Description We give the following inductive definition of a “regular brackets” sequence: the empty sequence is a regul…

从芯片到AI智能芯片,一文了解它的前世今生

作者 | 元宵大师&#xff0c;Python高级工程师&#xff0c;致力于推动人工智能、大数据分析在金融量化交易领域中的应用。欢迎大家关注我的个人公众号《元宵大师带你用Python量化交易》。责编 | 胡巍巍来源 | CSDN&#xff08;ID&#xff1a;CSDNnews&#xff09;经过长期的发展…

Windows7下OpenGL简单使用举例

1、 从http://www.opengl.org/resources/libraries/glut/glut_downloads.php下载glut相关头文件和库glutdlls37beta.zip &#xff0c;(默认的windows机子上并没有glut头文件及相应的库&#xff0c;它主要用来打开窗口、开发和管理菜单&#xff0c;以及管理事件等)&#xff0c;…

Snagit9-12注册码

SnagIt 9 注册码&#xff1a; AM5SC-8LWML-MVMWU-DTLGE-ERMBE SnagIt 10 注册码&#xff1a; 5HCAK-DEGMZ-EYABA-M4LCC-ACBE2 DFKDA-JZ5FC-TGLAA-CM5DM-MFEBD CMCFH-93DCD-SFZYC-K5KCM-C7CA7 SnagIt 11 注册码&#xff1a; 7CTCC-5WQCS-98AY8-V8F2M-76258 NCTCC-5WFCK-98A28-V8…

Strut2访问

访问HelloWorld应用的路径的设置 在struts2中&#xff0c;访问struts2中action的URL路径由两部份组成&#xff1a; 包的命名空间action的名称 例如: 访问本例子HelloWorldAction的URL路径为&#xff1a; /l6n/helloWorldAction (注意&#xff1a;完整路径为&#xff1a;http:/…

单v100 GPU,4小时搜索到一个鲁棒的网络结构

作者 | Slumbers&#xff0c;毕业于中山大学&#xff0c;深度学习工程师&#xff0c;主要方向是目标检测&#xff0c;语义分割&#xff0c;GAN责编 | JaneNAS最近也很火&#xff0c;正好看到了这篇论文&#xff0c;解读一下&#xff0c;这篇论文是基于DAG&#xff08;directed …

关于pyecharts 地图显示添加数据的问题

echarts &#xff1a; 香港地区显示&#xff08;人口密集的人口数目&#xff09; http://echarts.baidu.com/examples/editor.html?cmap-HK series: [ { name: 香港18区人口密度, type: map, mapType: HK …

MMX Intrinsics各函数介绍

SIMD相关头文件包括&#xff1a; //#include <ivec.h>//MMX //#include <fvec.h>//SSE(also include ivec.h) //#include <dvec.h>//SSE2(also include fvec.h)#include <mmintrin.h> //MMX #include <xmmintrin.h> //SSE(include mmintrin.h) #…

大数据中台向AI中台演进是大势所趋?

来源 | 宜信技术学院&#xff08;ID:CE_TECH&#xff09;导读&#xff1a;自从阿里巴巴提出“中台”的概念之后&#xff0c;这个词汇就成为各领域企业关注的焦点&#xff0c;很多人在考虑建设自己的中台。然而&#xff0c;构建中台是否真有必要&#xff1f;是否所有的企业都要建…

WordPress标签

1、分类目录调用函数&#xff1a; <?php wp_list_cats();?> 2、调用页面函数&#xff1a; <?php wp_nav_menu( array( theme_location > ast-menu-primary, container > false ) ); ?> 3、转载于:https://blog.51cto.com/okowo/…

SSE3和SSSE3 Intrinsics各函数介绍

SIMD相关头文件包括&#xff1a; //#include <ivec.h>//MMX //#include <fvec.h>//SSE(also include ivec.h) //#include <dvec.h>//SSE2(also include fvec.h)#include <mmintrin.h> //MMX #include <xmmintrin.h> //SSE(include mmintrin.h) #…