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

公众号网站开发网络班级网站建设

公众号网站开发,网络班级网站建设,python为什么叫爬虫,wordpress阅读全文前言#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://wiki.neutronadmin.com/news/82627/

相关文章:

  • 看电视剧的免费网站大全如何开通个人网站
  • 专业网站制作公司招聘网络广告推广的兼职
  • 做任务领q币网站花木公司网站源码
  • 网站未授权cas要怎么做做lt行业的人让我登网站
  • 网站标识描述可以填关键词吗温州哪里做网站设计
  • 营销型企业、公司网站案例如何自建网站 卖东西
  • 专业3合1网站建设价格网站建设与代运营产品介绍
  • 培训型网站建设方案东莞广告公司电话
  • 网站小程序app定制开发wordpress 夜间模式
  • 网站在网络文化建设方面的成果深圳宝安中心区
  • vs和sql怎么做网站深圳宝安外贸网站建设公司
  • tornado 网站开发目前做哪个网站能致富
  • 服装电子商务网站版式设计网站建设活动
  • 手机网站与电脑网站兼容珠海手机网站建设
  • 现在济南可以正常出入吗企业网站优化策略
  • 网站登录按钮点击没反应什么原因淘宝入口
  • 商城网站建设都需要多少钱专业网站建设加工
  • 网站建站网站496565js网站效果
  • 免费做效果图的网站网站地图怎么提交
  • 手机管理网站模板宁波妇科医院私立哪家医院好
  • 鹤山网站建设花店网站建设论文
  • 单页营销网站后台做不了大流量网站
  • 石家庄建站培训网络免费推广网站
  • 南宁网站快速优网页编辑器怎么打开
  • 做啥英文网站赚钱网站建设业务提成
  • ssh jsp做网站海南省生态文明村建设促进会网站
  • 山东网站建设开发维护企查查免费查询
  • 如何用vs2012做网站做标签网站是什么
  • 专做药材的网站有哪些在上海做兼职在哪个网站
  • 合肥做微网站建设wordpress子页面不显示