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

网站建设 宣传单互联网推广渠道

网站建设 宣传单,互联网推广渠道,做网站需要会哪些编程语言,wordpress 极简 主题题目 给定一个包含正整数、加()、减(-)、乘(*)、除(/)的算数表达式(括号除外),计算其结果。 表达式仅包含非负整数,, - ,,/ 四种运算符和空格 。 整数除法仅保留整数部分。 * * 示例 1: 输入: “32X2” 输出: 7 import…

题目

给定一个包含正整数、加(+)、减(-)、乘(*)、除(/)的算数表达式(括号除外),计算其结果。
表达式仅包含非负整数,+, - ,,/ 四种运算符和空格 。 整数除法仅保留整数部分。 * *
示例 1:
输入: “3+2X2”
输出: 7


import java.util.Stack;public class Code {public int calculate(String s) {Stack<Integer> data_stack = new Stack<>();Stack<Character> char_stack = new Stack<>();int length = s.length();int i = 0;while (i < length){char c = s.charAt(i);if (c == ' '){ //空格直接跳过i++;} else if (checkNumber(c)){ //如果是数字,处理如多个数字的情况 如333+1中的333int tmp = 0;while (i < length && checkNumber(s.charAt(i))){tmp = tmp * 10 + (s.charAt(i) - '0');i++;}data_stack.push(tmp);} else if (c == '('){ //左括号 直接入栈char_stack.push(c);i++;} else if (c == ')'){ //右括号 出栈计算 直到碰到'('为止while (!char_stack.isEmpty() && char_stack.peek() != '('){fetchAndCol(data_stack,char_stack);}char_stack.pop(); //弹出'('i++;} else {//如果字符栈为空 或者 运算字符 优先级 大于 栈顶字符,则运算字符直接入栈if (char_stack.isEmpty() || checkChar(c,char_stack.peek())){char_stack.push(c);} else {//优先级: 运算字符 <= 栈顶字符 ,则拿数字栈的前两个数字和栈顶字符栈计算,并把结果压入数字栈while (!char_stack.isEmpty() && !checkChar(c,char_stack.peek())){fetchAndCol(data_stack,char_stack);}char_stack.push(c); //最后再把字符入字符栈}i++;}}//如果字符栈不为空,则开始最后的计算,最后数字栈里只有一个最后计算的结果while (!char_stack.isEmpty()){fetchAndCol(data_stack,char_stack);}return data_stack.pop();}//计算数字栈和运算符栈public void fetchAndCol(Stack<Integer> data_stack,Stack<Character> char_stack){Integer pop1 = data_stack.pop();Integer pop2 = data_stack.pop();Character pop = char_stack.pop();Integer math = math(pop1, pop2, pop);data_stack.push(math);}public Integer math(Integer number1,Integer number2,char c){if (c == '+') return number1 + number2;if (c == '-') return number2 - number1;if (c == '*') return number1 * number2;if (c == '/') return number2 / number1;else return -1;}public boolean checkChar(char c,char top){if ((c == '*' || c == '/') && (top == '+' || top == '-')) return true;if (top == '(') return true; //栈顶运算符是'(' 也是返回trueelse return false;}//判断是否是数字public boolean checkNumber(char c){if (c >= '0' && c <= '9') return true;else return false;}
}
http://www.dinnco.com/news/23068.html

相关文章:

  • 公安局网站不备案南京网络营销服务
  • 怎么做英文的网站免费建站系统哪个好用吗
  • 长沙优化网站技巧企业网站的基本功能
  • 海南最新疫情今天新增厦门网站综合优化贵吗
  • 做网站什么语言最好百度推广需要什么条件
  • 仿 手机 网站模板html源码下载如何推广app更高效
  • 开发网站用那个平台网站优化公司哪家效果好
  • 学做川菜最好的网站成都最新疫情
  • 北京网站建设分析论文seo推广费用需要多少
  • 免费网站mvapp投放渠道有哪些
  • 深圳网站seo建设b站2023年免费入口
  • 网站建设新技术怎么申请自己的网络平台
  • 湛江网站建设模板百度风云榜官网
  • 网站纯色背景图怎么做关键词自助优化
  • 博客网站做外贸可以吗网站广告费一般多少钱
  • 建网站英语腾讯会议价格
  • 合肥做百度网站怎么优化电脑系统
  • 做网站发布信息南京网站排名提升
  • 网站是如何优化的大学生网络营销策划书
  • 鞍山做网站公司排名点击工具
  • 闲置服务器做网站台州网站seo
  • wordpress橱窗插件seo关键词选取工具
  • 建设网站什么软件比较好seo网络优化公司
  • 建网站用什么系统百度推广的四种收费形式
  • 手机网站免费的提高百度搜索排名工具
  • 怎么怎么做网站百度官网登录
  • 什么网站上做任务赚钱东莞网络营销公司
  • 石家庄市网站制作网站seo外链平台
  • crazygames游戏网站营销策略的思路
  • 我市精神文明建设的门户网站是办公软件培训