[leetcode]224. Basic Calculator --JavaScript 代码
2016-08-12 15:50
429 查看
这道题的tag里写着stack呢,因此,就要考虑使用栈来完成题目。
这道题据说很经典,我在编写计算器的程序时,也遇到过类似的问题。
思路:
当没有遇到运算符的时候,就一直解析字符串中的数字,并将它们转化为真正的数字。如果遇到加号或者减号,就改变标志位,如果遇到括号,就借助栈来完成运算。遇到 “(” 入栈,遇到 “)” 出栈并计算结果。
这道题据说很经典,我在编写计算器的程序时,也遇到过类似的问题。
思路:
当没有遇到运算符的时候,就一直解析字符串中的数字,并将它们转化为真正的数字。如果遇到加号或者减号,就改变标志位,如果遇到括号,就借助栈来完成运算。遇到 “(” 入栈,遇到 “)” 出栈并计算结果。
/** * @param {string} s * @return {number} */ var calculate = function(s) { var len = s.length; if(len === 0){ return 0; } var stack = []; var res = 0; var sign = 1; for(var i=0;i<len;i++){ var n = s.charAt(i); if (!isNaN(parseInt(n))){ var cur = parseInt(n); while(i+1<len && (!isNaN(parseInt(s.charAt(i+1))))){ cur = 10*cur + parseInt(s.charAt(++i)); } res += sign * cur; } else if (n=="-"){ sign = -1; } else if (n=="+"){ sign = 1; } else if (n=="("){ stack.push(res); res = 0; stack.push(sign); sign = 1; } else if (n==")"){ res = stack.pop() * res + stack.pop(); sign = 1; } } return res; };
相关文章推荐
- JQuery1——基础($对象,选择器,对象转换)
- Android学习笔记(二九):嵌入浏览器
- Android java 与 javascript互访(相互调用)的方法例子
- JavaScript演示排序算法
- javascript实现10进制转为N进制数
- 最后一次说说闭包
- Ajax
- 2019年开发人员应该学习的8个JavaScript框架
- HTML中的script标签研究
- 对一个分号引发的错误研究
- 设计模式---状态模式在web前端中的应用
- 异步流程控制:7 行代码学会 co 模块
- ES6 走马观花(ECMAScript2015 新特性)
- JavaScript拆分字符串时产生空字符的原因
- Canvas 在高清屏下绘制图片变模糊的解决方法
- Redux系列02:一个炒鸡简单的react+redux例子