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

你可能感兴趣的文章
Nagios 3.0 Jumpstart Guide For Linux – Overview, Installation and Configuration
查看>>
nagios 实时监控 iptables 状态
查看>>
WAP短信格式解析及在Linux下用C语言实现
查看>>
nagios+cacti整合
查看>>
Nagios介绍
查看>>
nagios利用NSCient监控远程window主机
查看>>
nagios安装文档
查看>>
nagios服务端安装
查看>>
Nagios自定义监控脚本
查看>>
name_save matlab
查看>>
Nami 项目使用教程
查看>>
Nancy之基于Nancy.Hosting.Aspnet的小Demo
查看>>
NAND NOR FLASH闪存产品概述
查看>>
nano 编辑
查看>>
nanoGPT 教程:从零开始训练语言模型
查看>>
NASA网站曝严重漏洞,或将沦为黑客钓鱼网站?
查看>>
Nash:轻量级、安全且可靠的脚本语言
查看>>
NAS、SAN和DAS的区别
查看>>
NAS个人云存储服务器搭建
查看>>
NAS服务器有哪些优势
查看>>