当前位置: 首页 > news >正文

兰州城建设计院网站网页设计代码如何写实训报告过程

兰州城建设计院网站,网页设计代码如何写实训报告过程,wordpress 在线生成app,东莞建设网东莞市住房和城乡前言#xff1a;四则运算#xff0c;大家都不陌生#xff0c;在上小学的时候#xff0c;数学中学到过的知识#xff0c;那么如何在程序中实现呢#xff1f;下面#xff0c;我们就用程序来实现9(3-2)*(5-3)/4*3#xff0c;这个算式的值。计算的时候#xff0c;有一个规…前言四则运算大家都不陌生在上小学的时候数学中学到过的知识那么如何在程序中实现呢下面我们就用程序来实现9(3-2)*(5-3)/4*3这个算式的值。计算的时候有一个规则”先乘除后加减从左到右先括号内后括号外“。 其优先级就是 加减乘除括号 这个算式我们可以很轻松的计算出它的值等于10.5。这是我们常用的四则表达式又叫做中缀表达式。这种计算的复杂之处在与乘除在加减之后并且还有括号放在程序里的判断就复杂了那么如何简化呢伟大的科学家想到了好的处理办法 一、逆波兰Reverse Polish NotationRPN一种不需要括号的后缀表达法我们也称之为逆波兰。 上面的四则运算表达式转换未后缀表达法之后变为 9 3 2 - * 5 3 - 4 / 3 * 叫后缀的原因所有的符号都是在要运算数字的后面出现。 如何实现由中缀表达式转化未后缀表达式呢 规则依次从左向右遍历表达式若是数字加入到集合若是符号则需要判断其与栈顶符号的优先级如果当前元素是右括号或优先级较低的符号则栈顶的元素一次出栈并输出并将当前符号进栈如果当前元素和栈顶的元素优先级相同将栈顶的同级元素依次出栈。 实现代码 /// summary /// 利用正则表达式分别获取数字和符号然后组装到集合中。 /// /summary /// param namestr/param /// returns/returns private Liststring GetOpList(string str) {string pattern (\d);Regex validate new Regex(pattern);MatchCollection col validate.Matches(str);//string patternFh ((\|\-|\*|\/|\(|\)));string patternFh \D;Regex validateFh new Regex(patternFh);MatchCollection colFh validateFh.Matches(str);Liststring list new Liststring();int nFhIndex 0;for (int i 0; i col.Count; i){Match mD col[i];list.Add(mD.Value);if (nFhIndex colFh.Count){Match mf colFh[nFhIndex];string strTemp mf.Value;int nTempLen strTemp.Length;for(int j 0; j nTempLen; j){list.Add(strTemp.Substring(j, 1));}nFhIndex;}}return list; }/// summary /// 当前只限定加减乘除小括号 /// /summary /// param namestr/param /// returns/returns private Liststring GetNextPrevRegex(string str) {string hig */; //优先级高的string zkh (; //左括号string ykh ); //右括号Stack stack new Stack();Liststring list new Liststring();Liststring listOp GetOpList(str);//从左到右遍历中缀表达式的每个数字和符号for (int i 0; i listOp.Count; i){string item listOp[i];//1、若是数字输出即成为后缀表达式的一部分if (IsNumeric(item)){list.Add(item);continue;}if (stack.Count 0 || zkh item){stack.Push(item);continue;}//这里限定了默认条件是必须-*/)才到这里。while (stack.Count 0){string ab stack.Peek().ToString();if (ykh item){if (zkh ab){stack.Pop(); //将左括号出栈break;}list.Add(stack.Pop().ToString());continue;}if (!hig.Contains(ab))break;list.Add(stack.Pop().ToString());}if (!ykh.Contains(item))stack.Push(item);}while (stack.Count 0){list.Add(stack.Pop().ToString());}return list; }private bool IsNumeric(string token) {bool blag true;string pattern (^\d$);Regex validate new Regex(pattern);if (!validate.IsMatch(token)){blag false;}return blag; } 二、由上面计算得到后缀表达式那么如何使用栈来计算这个表达式呢 计算规则依次遍历后缀表达式如果是数字则入栈如果是符号则将栈顶的两个元素出栈进行计算计算完成之后将结果入栈。 代码如下 public double GetResult(string calc) {Liststring list GetNextPrevRegex(calc);Stack calcStack new Stack();foreach (var item in list){string temp item.ToString();//如果是数字入栈if (IsNumeric(temp)){calcStack.Push(temp);continue;}//如果是符号则把栈顶的两个数字出栈进行计算入栈。double.TryParse(calcStack.Pop().ToString(), out double hz2);double.TryParse(calcStack.Pop().ToString(), out double hz1);double result GetResultByFh(hz1, hz2, temp);calcStack.Push(result);}string sResult calcStack.Pop().ToString();double.TryParse(sResult, out double calcresult);return calcresult; } private double GetResultByFh(double ca1, double ca2, string fh) {if (fh )return ca1 ca2;else if (fh -)return ca1 - ca2;else if (fh *)return ca1 * ca2;elsereturn ca1 / ca2; } 备注其中逆波兰解释来自《大话数据结构》一书。 欢迎大家批评指正小可不胜感激。
http://www.yutouwan.com/news/128846/

相关文章:

  • 做qq空间网站api低代码开发平台
  • 大连房地产网站建设一般做网站哪家好
  • 最低价网站建设宁波网络营销方式
  • 网站开发需要多少钱服务网站开发如何设置背景图片
  • 广州市建设交易服务中心网站长沙软件搭建公司
  • 外贸网站违反谷歌规则盘锦做网站
  • 网站无法上传图片广州技术支持 骏域网站建设
  • 合肥网站制作软件会员管理系统多少钱
  • 杭州 seo网站建设 网络服务渭南市工程项目网上审批大厅
  • 外贸建站教程设计手机网站
  • 定制做网站设计网页游戏排行榜前十名wangyi
  • 东营网站建设哪家更好设计在线观看2014
  • 网站 月15g流量够用吗wordpress搜索 文章
  • 用户密码找回网站网络营销是什么专学科
  • 腾讯公司做的购物网站wordpress管理主体
  • 信誉好的专业网站建设产品详情页模板免费下载
  • 网站安全维护方案wordpress中文下载方法
  • 营销型网站设计注意内衣网站建设推广
  • 如何查询网站点击量我想找个郑州做网站的
  • 延长中路上海网站建设中企动力主要是做什么的
  • 免费成品网站那里好营销渠道策略
  • 国内网站建设发展中小企业 wordpress
  • 利趣网站开发商怎么做免费的企业网站
  • 建网站要去备案抖音上的小程序怎么赚钱
  • 嘉兴做营销型网站设计西安最新传染病
  • 网站建设制作包括哪些方面漳州做网站
  • 免费文档网站网站制作河南
  • 网站建设应该懂什么知识购物网站前端浮动特效怎么做
  • 短信验证码接码网站建设知名企业网站搭建品牌
  • 如何搭建自己的网站平台aardio 网站开发