Evaluate Reverse Polish Notation

Evaluate the value of an arithmetic expression in Reverse Polish Notation.

Valid operators are +-*/. Each operand may be an integer or another expression.

Some examples:

  ["2", "1", "+", "3", "*"] -> ((2 + 1) * 3) -> 9
  ["4", "13", "5", "/", "+"] -> (4 + (13 / 5)) -> 6

c++代码:

//Evaluate Reverse Polish Notation 
#include<iostream>
#include<string>
#include<vector>
#include<stack>
#include<algorithm>
using namespace std;

class Solution {
public:
    int evalRPN(vector<string> &tokens) {
        stack <int> stk;
        vector<string>::iterator it;
        for(it=tokens.begin(); it!=tokens.end(); ++it)
        {
        	if(isoperator(*it))
        	{
        		int a = stk.top();
        	//	cout<<a<<*it;
        		stk.pop();
        		int b = stk.top();
        	//	cout<<b;
        		stk.pop();
        		stk.push(operates(a,b,*it));
        	//	cout<<"="<<stk.top()<<endl;
        	}
        	else
        		stk.push(atoi((*it).c_str()));
        }
        
        return stk.top();
    }
    bool isoperator(string st)
    {
   	    if(st=="+" || st=="-" || st=="*" || st=="/")
    	   return true;
 	    return false;
    }
    int operates(int a,int b, string op)
    {
    	if(op=="+")
    	{
    		return a+b;
    	}
    	if(op=="-")
    	{
    		return b-a;
    	}
    	if(op=="*")
    	{
    		return a*b;
    	}
    	if(op=="/")
    	{
    		return b/a;
    	}
    }
};

int
main(void)
{
    string str[]= {"4", "3", "-"}; 	 
    vector<string> strArray(str,str+(sizeof(str)/sizeof(str[0])));
	Solution sn;
	cout<<sn.evalRPN(strArray);
		
	return 0;
}


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值