上一篇:用VC实现特定编辑框上对回车键响应 >>
用Visual C# 实现四则混合运算
| 天极软件专题专区精选 | ||
| Google专区 | POPO专区 | QQ专区 |
| Flash MX 视频教程 | Photoshop视频教程 | 网页设计视频教程 |
| PowerPoint动画演示教程 | Excel动画教程集 | Word动画演示教程 |
| 特洛伊木马专区 | 黑客知识教程专区 | 注册表应用专区 |
| Windows API开发专区 | 网络编程专区 | VB数据库编程专区 |
| 图像与多媒体编程 | Windows Vista应用专区 | 防火墙应用专区 |
本文是介绍使用Visual C#实现自动计算四则混合运算的一种方法,在.NET1.1框架中,还没有包含全现成的类,不过,现在经过我们下文的介绍,大家完全可以自己写一个,作用嘛,没什么,就是熟悉一下栈的用法,或者家里有上小学的,可以写一个程序给孩子练习一下四则混合运算也行,哈哈,废话不多说了,讲正题吧。
出一个典型的算术题: (6+2*5)/4
从题中,我们首先算 2*5=10 接下来算 6+10=16 最后算 16/4 =4 所以,结果是4
计算机怎么算?还好前辈给我们列出来一堆的算法,我们随便选一个就可以了。
第一种算法
使用栈来解决,意思就是把不优极最低的压到栈的最下面去,按照先进后出的原则,那么最优先级最低的就是最后计算了。
计算过程:
我们建立两个栈,一个是数据栈,一个是计算符号栈,以(6+2*5)/4为例子,看看倒底是怎么计算的。
假设:
1)优先级
符号之间的优先级如下:
“(“ “)” -1
“+”,”-” 0
“*”,”/” 1
数值越大,则越优先,同级别的比较时 先出现的优先。
2)将”(”,”)”设为特殊运算符,即单目运算,两邻两个运算符则可对消。
3) 计算条件
(1) 当前运算符不等于“”(特殊结束符)
(2) 运算符栈里的运行算个数>=1时
(3) 出栈口的运算符优先级高于将要入栈的运算符时或者两者可对消时。
计算时,则将符号出栈参与计算,数值栈的出栈口前两位元素出栈参与计算,计算结果值向数值栈压栈,并进行递归此操作。
|
图1: |
1) “(” 压入符号栈 2 ) “6”压入数值栈
3) “(”与”+”比较优先级,认为”(”比”+”优先级低,则不满足计算条件,将”+”压入符号栈.
|
图2: |
1) 将”2” 压入数值栈。
2) 将”*”与”+”比较优先级,算得”+”优先级低于”*”,则不满足计算条件,将”*”压入符号栈。
|
图3: |
1) 将 “5”压入数植栈。 2) 将“*“与”)”比较优先级,得出”*”比”)”优先级要高。进行计算,将”*”出栈、”5”、”2”出栈,参与计算
|
图4: |
1) 将 2*5 =10的结果压入数值栈。
2) (递归)比较 “+”与”)”优先级,得出”+”比”)”优先级要高。再进行计算,将”+”出栈、”10”、”6”出栈,参与计算。
|
图 5: |
1) 将 6+10 =16的结果压入数值栈。
2) (递归)比较 “)”与”(”优先级,得出两者可以对消,将”(”符号出栈,与”)”对消,继续取下一个符号。
|
图6: |
1) 将”/”入符号栈。
2)将”4”入数值栈。
3) 发现””算式结束符,则进行计算, 将 “/”、”4’、”16”出栈,参与计算。
|
图7: |
1) 将计算结果压入数值栈。
成功了! 辛苦的计算工作终于干完了,看起来比人脑计算复杂多了:)
第二种算法
第二种方法,我们简单的提一下,在这里不作详细过程的叙述。第二种,就是使用树的方式,将一个算式组织成一定规律的树,之后,再进行遍历计算即得得到结果。还是以上面的算式作例子,最终形成的树的样式:(注意“()”这个符号要特殊处理)
|
图8: |
使用树的深度遍历即可算出最终的结果。
下一篇:C#中利用mediaplayer打造mp3播放器 >>
相关文章:
- · James Gosling预言Java:手机将一统桌面
- · 美杂志评25件最糟糕IT产品 Win2000上榜
- · Java初学者都必须理解的六大问题
- · 两种特殊的Java容器类List和Set分析
- · 06年搜索市场十五大趋势 Google唱主角
- · Delphi实现动态修改显示器分辨率
- · 更改IE下载文件后的默认处理方法
- · 网管必备的智能监控软件:网络执法官
- · 用Delphi设计循环播放声音文件程序
- · Delphi编程禁止用户关闭操作系统
- · PHP 5.0 中的对象重载技术研究
- · 美政府黑客大会寻人才 培养黑客界线人
- · 腾讯RTX能带给企业客户的价值
- · 腾讯RTX提供给用户的主要解决方案
- · 腾讯RTX的主要功能特性介绍
- · MM购物人人埋单 人人网重金搜寻品味美女
- · 是猫友就要有猫窝!猫扑我的空间试用小记
- · UUME引领网络视频娱乐狂潮
- · 让我们停止这场战争
- · 一个“小圈子”,聚拢大家庭
- · 个人博客盈利并不难 要根据特点选对广告
- · 猫扑网友热心公益 齐力捐助善良老人
- · 猫扑网友自拍漫画玩火世界杯
- · 美少女足球队让你High到爽
- · 激情盛夏 趋势科技送大礼
- · 把软件当硬件卖 趋势给中国市场的独创方案
- · 我的媒体中心—“猫仔队1.7”新鲜登场
- · 猫扑音乐随身听,保护数字音乐版权有新招
- · 网络创业者们看过来 网站的盈利方式
- · 警报:转信服务已危及全球Internet安全
- · 百度硬盘搜索2.0 Beta版抢先试用
- · 继续前行 百度硬盘搜索发布一周年
- · 百度超级搜霸有六大搜索利器
- · 百度搜霸——让你做个精明的管家
- · 启动3D聊天模式 与Q友站到系统桌面上畅聊
- · 体验腾讯QQ新酷功能——3D秀
- · QQ新版3月发布 增3D秀、网络城市等新元素
- · QQ宠物常见问题解答(十四)
