当前位置: 首页 > 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.huolong8.cn/news/316061/

相关文章:

  • 潮阳网站开发空间设计logo
  • 网站管理助手+建设中wordpress产品幻灯片
  • 网站建设怎么找客源?wordpress点击慢
  • 百度站长工具app响应式网站模板dede
  • 公司门户网站首页建站需要哪些东西
  • 如何备份网站的网络公司官网
  • 阿里云二级域名建设网站展馆设计方案
  • 毕业设计网站选题怎样开发公司的网站建设
  • 商业网站建设开发网页设计的风格
  • 网站的评测系统怎么做的新网建站教程
  • 信誉好的龙岗网站设计办公管理软件
  • 制作自己的网站需要什么青羊区城乡建设网站
  • 嘉兴品牌网站设计微信公众平台网页
  • 中英文的网站怎么建设装修网站建设优缺点
  • 网站代备案公司名称多店铺商城系统
  • 深圳做三网合一网站优秀设计师网站
  • 搜狗做网站怎么样工程公司取名大全
  • 大型网站开发费用手机百度极速版
  • 备案号 网站wordpress 批量发布器
  • 收费下载网站源码做衣服网站
  • 摄影作品投稿网站网约车服务
  • 邢台好蜘蛛网站建设嵌入式开发就业前景
  • 建站系统模板青岛软件开发公司有哪些
  • 建设网站制作项目描述aws 高可用 WordPress
  • 网站开发费入什么科目wordpress点击分类目录空白
  • 电子商务网站建设的步骤一般祥云平台官方网站
  • 做网站作业什么主题设计师的招聘要求
  • 做一般的公司门户网站投资额上海网站制作商
  • 电子商务网站开发总结山西泽庆建设公司官网
  • 备案个人网站 淘宝客厦门建站最新消息