博客
关于我
150. 逆波兰表达式求值 (栈)
阅读量:376 次
发布时间:2019-03-05

本文共 1006 字,大约阅读时间需要 3 分钟。

分析

本题和的区别在于:

本题直接是后缀表达式,不需要进行处理,直接让2个数字出栈进行运算即可。
而计算器那道题为中缀表达式,需要对符号的优先级进行判断。

C++ 代码

class Solution {public:    stack
stk1; //只需要设置一个数字栈就可以了 bool static dg(char c) //判断是否为合法数字 { if(c>='0' && c<='9') return true; return false; } int getc(string c) //判断符号是什么 { if(c=="+") return 1; if(c=="-") return 2; if(c=="*") return 3; return 4; } int evalRPN(vector
& s) { int n=s.size(); for(int i=0;i
1 && s[i][0]=='-')) //第一位为数字 或者 是一个负数 { stk1.push(stoi(s[i])); //数字栈压入转换为数字的s[i] } else{ //进行运算 auto a=stk1.top(); stk1.pop(); auto b=stk1.top(); stk1.pop(); int c=getc(s[i]); if(c==1) b+=a; if(c==2) b-=a; if(c==3) b*=a; if(c==4) b/=a; stk1.push(b); } } return stk1.top(); //最终栈顶元素一定是结果 }};

转载地址:http://poag.baihongyu.com/

你可能感兴趣的文章
mysql字段类型介绍
查看>>
mysql字段解析逗号分割_MySQL逗号分割字段的行列转换技巧
查看>>
MySQL字符集与排序规则
查看>>
MySQL字符集乱码
查看>>
mysql存储IP地址的数据类型
查看>>
mysql存储中文 但是读取乱码_mysql存储中文乱码
查看>>
MySQL存储引擎--MyISAM与InnoDB区别
查看>>
mysql存储总结
查看>>
mysql存储登录_php调用mysql存储过程会员登录验证实例分析
查看>>
MySql存储过程中limit传参
查看>>
MySQL存储过程入门
查看>>
mysql存储过程批量建表
查看>>
MySQL存储过程的使用实现数据快速插入
查看>>
mysql存储过程详解
查看>>
Mysql存表情符号发生错误
查看>>
MySQL学习-group by和having
查看>>
MySQL学习-MySQL数据库事务
查看>>
MySQL学习-MySQL条件查询
查看>>
MySQL学习-SQL语句的分类与MySQL简单查询
查看>>
MySQL学习-子查询及limit分页
查看>>