收藏本站
收藏本站
积木网首页
-
软件测试
-
常用手册
-
站长工具
-
技术社区
积木学院
>
黑客技术
>
黑客编程
> 正文
搜一搜
首页
|
开发语言
数据库
|
网页制作
|
操作系统
服务器
|
安全
黑客技术
|
搜索引擎优化
电脑办公
|
网文精粹
标签
菜鸟入门
黑客编程
黑客工具
病毒漏洞
入侵实例
其他黑客相关
用Visual C# 实现四则混合运算
来源:互联摘选 日期:2007-08-28 16:02
本文是介绍使用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:
使用树的深度遍历即可算出最终的结果。
[1]
[2] 下一页
相关阅读
利用Visual C#实现Reversi游戏开发
Visual C#实现文件分割合并器
利用Visual C#实现ICMP网络协议
用Visual C#实现文件下载功能(2)
开发工具大比拼visual c++ vs delphi---(三)
推荐阅读
[jQuery]
JQuery实现倒计时按钮的实现代码
[jQuery]
JQuery防止退格键网页后退的实现代码
[jQuery]
jQuery中将函数赋值给变量的调用方法
[jQuery]
jQuery中判断一个元素是否为另一个元素的子元素(或者其本身)
[jQuery]
Jquery实现简单的动画效果代码
[jQuery]
jQuery控制图片的hover效果(smartRollover.js)
[jQuery]
基于jQuery的弹出框插件
[jQuery]
Jquery命名冲突解决的五种方案分享
[jQuery]
让人期待的2011年度最佳 jQuery 插件分享
[jQuery]
使用Jquery Aajx访问WCF服务(GET、POST、PUT、DELETE)
热点信息
域名MX记录查询
域名查IP地址
检测网站速度(HTTP测速)
检测服务器速度(TCP测速)
查询网页Header头信息
字符串MD5加密
检测网页是否有301重定向
网页死连接检查
模拟搜索引擎抓取URL连接
网页Meta信息查询
强悍的草根IT技术社区,这里应该有您想要的!
Copyright © 2010 Gimoo.Net. All Rights Rreserved
京ICP备05050695号