1、利用栈(Stack)来存储操作数和操作符;
 2、包含中缀表达式转后缀表达式的函数,这个是难点,也是关键点;
  2.1、将输入字符串转为数组;
  2.2、对转换来的字符进行遍历;创建一个数组,用来给存储转换为后缀表达式的字符;创建一个栈,用来存储操作符;
  2.3、通过正则来过滤,为数字的则放在数组中,其他的则放在栈中;
  2.4、接下来是最麻烦的操作符判断,我做的这个比较简单,如果再复杂些,我这个可能还要进行扩展或优化;
  2.5、对操作符的判断按照其优先级来,首先是括号,有‘(’,直接压人,等到有‘)’的时候再一个个的将括号内的操作符进行弹出,如果里面有两个以上,则要先弹
      靠近‘(’的;
  2.6、然后是乘除。这里,我将乘除的弹栈放在了它的入栈前面,两则并不冲突,也不会对其他操作符有影响,因为它在添加数字的时候,就把乘或除弹出来了添加到数组;
  2.7、上一个乘或除已经被弹出去了,数字添加后,如果后面字符是乘或除,则就直接入栈。(比如测试testing中的第一字符串,有连个两个乘);
  2,8、最后是加减。首先,如果是空栈,直接入栈,如果不是空栈,则判断栈顶是否有‘(’,有则直接入栈,如果栈顶这些情况都没有(前面已经经乘除考虑了,这里就无需考虑了),
      则说明栈内都是加或减,这时可以
将栈顶元素弹栈,并添加到数组中,再将当前操作符入栈。
 3、包含后缀表达式的计算方式;
 4、利用主函数main来调用;
 5、cmd测试。

 function Stack(){
this.store = [];
this.top = 0;
this.push = push;
this.pop = pop;
} function push(ele){
this.store[this.top++] = ele;
} function pop(){
var top = --this.top;
if(top >= 0){
var val = this.store[top];
//-----------------务必删除弹出栈的值原来的空间----------------------------
this.store.splice(this.top,1);
return val;
}else{
return 'It\' Ending !';
} }
//----------------中缀表达式转后缀表达式-----------------------------------
function normalChar(normalC){
normalC = normalC.split(' ');
var arr = [];
var ls = new Stack();
var reg = /\d/; for(var i=0; i<normalC.length; i++){
if(reg.test(normalC[i])){
arr.push(normalC[i]); }
if(normalC[i] == '('){
ls.push(normalC[i]);
}
else if(normalC[i] == ')'){
while(ls.store[ls.top-1] != '('){
arr.push(ls.pop());
}
ls.pop();
}
//-----------------此处是在添加数字的时候进行的,不会和其他操作符发生冲突--
else if(ls.store[ls.top-1] == '*' || ls.store[ls.top-1] =='/'){
arr.push(ls.pop());
} else if(normalC[i] == '*' || normalC[i] =='/'){
ls.push(normalC[i]); }
else if(normalC[i] == '+' || normalC[i] =='-'){
if(ls.top == 0){
ls.push(normalC[i]);
}
else if(ls.top > 0){
if(ls.store[ls.top-1] == '('){
ls.push(normalC[i]);
}else{
arr.push(ls.pop());
ls.push(normalC[i]);
}
} } }
while(ls.store != 0){
arr.push(ls.pop());
}
return arr;
console.log(arr);
} //------------------------Testing---------------------------------------
function main(){
//输入时做提示,以空格间隔每个操作符和操作数
//var normalC = ' 1 - ( 2 + 3 ) * 4 * 2 + 10 / 5 ';
var normalC = '2 + 3 * 4 * ( 3 - 2 )';
var stack = new Stack();
var char = normalChar(normalC);
var p = 0,s = 0;
var reg = /\d/;
for(var i=0; i<char.length; i++){
if(reg.test(char[i])){
stack.push(char[i]);
}else{
switch(char[i]){
case '-':
p = stack.pop();
s = stack.pop();
stack.push(Number(s)-Number(p));
break;
case '+':
p = stack.pop();
s = stack.pop();
stack.push(Number(s)+Number(p));
break;
case '*':
p = stack.pop();
s = stack.pop();
stack.push(Number(s)*Number(p));
break;
case '/':
p = stack.pop();
s = stack.pop();
if(p != 0){
stack.push(Number(s)/Number(p));
}else{
console.log("除数不能为0");
break;
}
}
}
}
console.log(stack.store);
}
main();

RPN-逆波兰计算器-中缀表达式转后缀表达式-javascript的更多相关文章

  1. 6, java数据结构和算法: 栈的应用, 逆波兰计算器, 中缀表达式--> 后缀表达式

    直接上代码: public class PolandCalculator { //栈的应用:波兰计算器: 即: 输入一个字符串,来计算结果, 比如 1+((2+3)×4)-5 结果为16 public ...

  2. C#数据结构与算法系列(十):逆波兰计算器——逆波兰表达式(后缀表达式)

    1.介绍 后缀表达式又称逆波兰表达式,与前缀表达式相似,只是运算符位于操作数之后 2.举例说明 (3+4)*5-6对应的后缀表达式就是3 4 +5 * 6 - 3.示例 输入一个逆波兰表达式(后缀表达 ...

  3. 栈的简单应用之中缀表达式转后缀表达式(C语言实现逆波兰式)

    一.前言   普通人在书写计算式时会选择中缀表达式,这样符合人脑的认知习惯.可计算机处理时后缀表达式才能使处理速度更快,其原因是利用堆栈结构减少计算机内存访问.同时它也是一个很好锻炼栈这个数据结构的应 ...

  4. hdu-1237 简单计算器---中缀表达式转后缀表达式

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=1237 题目大意: 读入一个只包含 +, -, *, / 的非负整数计算表达式,计算该表达式的值. 思路 ...

  5. .net表达式计算器(中缀表达式转后缀表达式,支持20多个数学函数,支持函数嵌套)

    最近在网上查了一下表达工计算器的类库,发现Java版本的有一个比较成熟的叫W3EVal,好像是一个IBM工程师写的,.net就很少了(可能是我了解不够多),但投机取巧的实现思路有很多,比如: (1)将 ...

  6. javascript使用栈结构将中缀表达式转换为后缀表达式并计算值

    1.概念 你可能听说过表达式,a+b,a+b*c这些,但是前缀表达式,前缀记法,中缀表达式,波兰式,后缀表达式,后缀记法,逆波兰式这些都是也是表达式. a+b,a+b*c这些看上去比较正常的是中缀表达 ...

  7. 怎么实现Linux下的逆波兰计算器dc?

    #返回上一级 @Author: 张海拔 @Update: 2014-01-12 @Link: http://www.cnblogs.com/zhanghaiba/p/3516660.html /* * ...

  8. 中缀表达式转后缀表达式(Java代码实现)

    后缀表达式求值 后缀表达式又叫逆波兰表达式,其求值过程可以用到栈来辅助存储.例如要求值的后缀表达式为:1 2 3 + 4 * + 5 -,则求值过程如下: 遍历表达式,遇到数字时直接入栈,栈结构如下 ...

  9. 利用stack结构,将中缀表达式转换为后缀表达式并求值的算法实现

    #!/usr/bin/env python # -*- coding: utf-8 -*- # learn <<Problem Solving with Algorithms and Da ...

随机推荐

  1. 使用JavaScript访问子节点方法elementNode.childNodes时,需要注意的地方

    有这样一个HTML结构 <div> javascript <p>javascript</p> <div>jQuery</div> <h ...

  2. win8/10 特技

    今天弄些特技: 1.图片批量命名:选中(1) 2.自动显示记录时间:在记事本中里面写上 .LOG  下次会自动把时间写上. 3.无密码登录:在命令行中输入:netplwiz,取消=>要使用本计算 ...

  3. mysql主从配置(基于mysql5.5.x)

    安装mysql数据库主从复制,步骤如下:1.主从服务器分别作以下准备:    1.1.数据库版本完全一致    1.2.修改root的密码, 不改也可以 2.修改主服务器master #vi /etc ...

  4. for循环嵌套的优化

    public static void main(String[] args) {     int x = 0;     for (int i = 0; i < 2; i++) {         ...

  5. EXCEL表格实现万位分隔符效果!

    单击单元格右键 选择自定义单元格格式 选择数字标签 选择自定义 在输入框中输入:###","#### 单击确定即可! 格式刷可以对其他单元格实行同样效果!

  6. 如何监控checkbox改变

    现在想实现一个效果,即使弹幕开关,弹幕开关实际是checkbox $(document).on('change',"#barrage",function(){ if (!$(thi ...

  7. [地图SkyLine二次开发]框架(2)

    上节讲到,地图加载. 但我们可以发现,当没有页面布局的情况下,<OBJECT>控件,没有占满整个屏幕,这里我们就要用到Extjs的功能了. 这节要讲的是用Extjs为<OBJECT& ...

  8. Error:No suitable device found: no device found for connection "System eth0"

    环境描述: Vmware 故障说明: 在克隆几台虚拟机,发现启动后不能配置IP地址等信息,使用linux命令: “ifup eth0”也不能激活网卡, 而在使用"service networ ...

  9. 7 -- Spring的基本用法 -- 3...

    7.3 Spring 的核心机制 : 依赖注入 Spring 框架的核心功能有两个. Spring容器作为超级大工厂,负责创建.管理所有的Java对象,这些Java对象被称为Bean. Spring容 ...

  10. 推荐两个谷歌的json-view插件(附带下载分享地址)

    1.JSONView 网盘下载地址:http://pan.baidu.com/s/1hrGlaVa 效果图: 2.JSON-handle 网盘下载地址:http://pan.baidu.com/s/1 ...