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

wordpress更换系统上海seo公司推荐

wordpress更换系统,上海seo公司推荐,高唐做网站建设的公司,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 * 叫后缀的原因所有的符号都是在要运算数字的后面出现。 如何实现由中缀表达式转化未后缀表达式呢 规则依次从左向右遍历表达式若是数字加入到集合若是符号则需要判断其与栈顶符号的优先级如果当前元素是右括号或优先级较低的符号则栈顶的元素一次出栈并输出并将当前符号进栈如果当前元素和栈顶的元素优先级相同将栈顶的同级元素依次出栈。 实现代码 string str 9(3-2)*(5-3)/4*3; string cz )-; //需要出栈的操作 string rz (*/; //入栈的符号 string hig */; //优先级高的 string zkh (; //左括号 string ykh ); //右括号 Stack stack new Stack(); int lj str.Length - 1; ArrayList list new ArrayList(); //从左到右遍历中缀表达式的每个数字和符号 for (int i 0; i str.Length; i) {string item str.Substring(i, 1);//1、若是数字输出即成为后缀表达式的一部分if (digital.Contains(item)){Console.Write(${item}\t);list.Add(item);}else{//若是符号if (rz.Contains(item) || stack.Count 0){if (stack.Count 0){string chr (string)stack.Pop();if (hig.Contains(chr)){list.Add(chr);Console.Write(${chr}\t);}else{stack.Push(chr);}}stack.Push(item);}else{//优先级低与栈顶符号乘除优先加减则栈顶元素依次出栈并输出if (ykh.Contains(item)){while (stack.Count 0){string zk (string)stack.Pop();if (zkh.Contains(zk)){break;}list.Add(zk);Console.Write(${zk}\t);}continue;}if (cz.Contains(item)){string chr (string)stack.Pop();if (hig.Contains(chr)){list.Add(chr);Console.Write(${chr}\t);while (stack.Count 0){string ab (string)stack.Pop();list.Add(ab);Console.Write(${ab}\t);}}else{stack.Push(chr);}stack.Push(item);continue;}stack.Push(item);}}if (lj i){while (stack.Count 0){string ab (string)stack.Pop();list.Add(ab);Console.Write(${ab}\t);}}}Console.WriteLine();for(var i 0; i list.Count; i){string a list[i].ToString();Console.Write(${a} \t);} 二、由上面计算得到后缀表达式那么如何使用栈来计算这个表达式呢 计算规则依次遍历后缀表达式如果是数字则入栈如果是符号则将栈顶的两个元素出栈进行计算计算完成之后将结果入栈。 代码如下 string digital 0123456789; Stack calcStack new Stack(); foreach(var item in list) {//如果是数字入栈if (digital.Contains(item.ToString())){calcStack.Push(item);}else{//如果是符号则把栈顶的两个数字出栈进行计算入栈。string clfh item.ToString();double hz1, hz2;double.TryParse(calcStack.Pop().ToString(), out hz2);double.TryParse(calcStack.Pop().ToString(), out hz1);double result GetResult(hz1, hz2, clfh);calcStack.Push(result);} } Console.WriteLine(); Console.WriteLine(); while (calcStack.Count 0) {Console.WriteLine(${str} {calcStack.Pop()}); } private static double GetResult (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; } 备注其中逆波兰解释来自《大话数据结构》一书。 PS当前代码计算小于10的四则运算。 欢迎大家批评指正小可不胜感激。
http://www.zqtcl.cn/news/831335/

相关文章:

  • 不花钱怎么做网站运营定州网页设计
  • 公司注销后网站备案大型网站建设用什么系统好
  • 网站建设服务公司专业服务海外留学网站建设方案
  • 哈尔滨建站模板搭建马鞍山市网站建设
  • 上海网站设计专注乐云seo个人简介代码网页制作模板
  • 法律网站建设价格做视频周边的网站
  • 京东物流网站地方门户网站源码下载
  • 重庆建设工程信息网站企业宣传片制作公司光年映画
  • 哪家做网站好 成都ktv网络推广方案
  • 网站开发的软件支持哈尔滨最新消息
  • jsp淘宝客网站有限公司怎么注册
  • 香奈儿电子商务网站建设策划书怎样进行网络营销吸引顾客
  • 昆山网站建设费用我们公司想做网络推广
  • 网站建设一般要多少钱网站开发主要步骤
  • 商用图片的网站网络文化经营许可证查询
  • c 高性能网站开发弄一个公司网站需要多少钱
  • 建设部网站招标投标文件网页设计专业公司
  • 使用iis6搭建网站wordpress调用搜索功能
  • 装配式建筑网站生活家装饰
  • 怎样做软件网站建设百度网站认证官网
  • phpcms网站什么网站都能进的浏览器
  • 建设配资网站有要求吗网站建设不一定当地
  • 永兴网站开发智慧门店管理服务平台
  • 网站建设前的市场分析李炎辉网站建设教程
  • 乱起封神是那个网站开发的?广州市建设注册中心网站首页
  • 网站开发配置网络广告的投放技巧
  • wordpress 漫画网站安徽省建设厅八大员报名网站
  • 音乐网站排名建设部证书查询网站
  • 长沙建站挺找有为太极wordpress eshop 教程
  • 郑州平台类网站网站开发常见面试题