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

网站的盈利点网站自动适应屏幕

网站的盈利点,网站自动适应屏幕,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://www.sadfv.cn/news/316061/

相关文章:

  • 色彩网站设计师正规的培训机构有哪些
  • 专业电商网站海外推广什么意思
  • 网站开发培训机构排名学校网站建设厂家
  • 网站开发vs2015是什么wordpress 按钮
  • 维护网站要做哪些工作淘宝式网站建设
  • 西安免费企业网站模板图片婚恋网站设计
  • 北京营销型网站建设培训html网页制作基础教程
  • 虚拟主机做多个网站wordpress跟新到5.0.1是英文
  • 高品质网站开发wordpress 3.2 漏洞
  • 如何在自己网站做直播网站免费建站
  • 花都网站推广天津广告设计公司排名
  • 搜索关键字搜索到网站怎样在外国网站开发客户
  • 米拓做网站图片在哪里删掉东光网站建设
  • 旅游攻略网站源码网站建设学校培训班
  • 甘州区住房和城乡建设局网站免费做商城网站
  • 前端旅游网站行程怎么做学网站开发需要学那些
  • 坪山手机网站建设加快实施创新驱动发展战略
  • 万网网站模板横岗网站建设公司
  • 搜狗网站提交网站企业备案
  • 商标免费查询官网seo现在还有前景吗
  • 如何做百度推广网站网站开发语
  • 食品网站建设规划书vi设计案例ppt
  • 高校保卫处网站建设工作网站建设后台怎么修改
  • 鼓楼网站seo搜索引擎优化新建网站如何被搜索
  • flash网站收录中国女排赛程时间最新消息
  • 做家教在哪个网站wordpress建站 防攻击
  • 北京商城网站开发市政建设招标网站有哪些
  • 做词频分析的网站建设什么样的网站月入一万
  • 彩票计划网站开发WordPress修改分类id
  • 长春网站如何制作apache重定向wordpress