博客
关于我
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 分组统计SQL语句
查看>>
Mysql 分页
查看>>
Mysql 分页语句 Limit原理
查看>>
MySQL 创建新用户及授予权限的完整流程
查看>>
mysql 创建表,不能包含关键字values 以及 表id自增问题
查看>>
mysql 删除日志文件详解
查看>>
mysql 判断表字段是否存在,然后修改
查看>>
mysql 协议的退出命令包及解析
查看>>
mysql 取表中分组之后最新一条数据 分组最新数据 分组取最新数据 分组数据 获取每个分类的最新数据
查看>>
mysql 多个表关联查询查询时间长的问题
查看>>
mySQL 多个表求多个count
查看>>
mysql 多字段删除重复数据,保留最小id数据
查看>>
MySQL 多表联合查询:UNION 和 JOIN 分析
查看>>
MySQL 大数据量快速插入方法和语句优化
查看>>
mysql 如何给SQL添加索引
查看>>
mysql 字段区分大小写
查看>>