博客
关于我
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/

你可能感兴趣的文章
netty--helloword程序
查看>>
netty2---服务端和客户端
查看>>
Netty5.x 和3.x、4.x的区别及注意事项(官方翻译)
查看>>
netty——bytebuf的创建、内存分配与池化、组成、扩容规则、写入读取、内存回收、零拷贝
查看>>
netty——Channl的常用方法、ChannelFuture、CloseFuture
查看>>
netty——EventLoop概念、处理普通任务定时任务、处理io事件、EventLoopGroup
查看>>
netty——Future和Promise的使用 线程间的通信
查看>>
netty——Handler和pipeline
查看>>
Vue输出HTML
查看>>
netty——黏包半包的解决方案、滑动窗口的概念
查看>>
Netty中Http客户端、服务端的编解码器
查看>>
Netty中使用WebSocket实现服务端与客户端的长连接通信发送消息
查看>>
Netty中实现多客户端连接与通信-以实现聊天室群聊功能为例(附代码下载)
查看>>
Netty中的组件是怎么交互的?
查看>>
Netty中集成Protobuf实现Java对象数据传递
查看>>
netty之 定长数据流处理数据粘包问题
查看>>
Netty事件注册机制深入解析
查看>>
netty代理
查看>>
Netty入门使用
查看>>
netty入门,入门代码执行流程,netty主要组件的理解
查看>>