Evaluate Reverse Polish Notation

先附上我的code:

class Solution {  
public:  
    int evalRPN(vector<string> &tokens) {  
        stack<int> tmp;
        char t[256];
        int opnum3;
        
        if(tokens.size()==1)
        return atoi(tokens.front().c_str());
        
        while(tokens.size()>=1){
            while(isdigit(tokens.front()[0])||tokens.front().size()>1){
                tmp.push(atoi(tokens.front().c_str()));
                tokens.erase(tokens.begin());
                
                }
            
        
        string op=tokens.front();
        tokens.erase(tokens.begin());
        
        int opnum2=tmp.top();
        tmp.pop();
        int opnum1=tmp.top();
        tmp.pop();
       
        
        switch(op[0]){
            case '+': opnum3=opnum1+opnum2;break;
            case '-': opnum3=opnum1-opnum2;break;
            case '*': opnum3=opnum1*opnum2;break;
            case '/': opnum3=opnum1/opnum2;break;
        }
    
        tmp.push(opnum3);
        
        }
        return tmp.top();
        }
        
};  

刚开始接触leetcode,第一次做,这个题是计算逆波兰式,原理非常简单,就是用一个栈来存第一个运算符之前的运算数,然后根据两个栈顶的运算输和运算符计算出新的运算数,循环知道原栈没有元素。也许是很久没有写代码了,这么简单的算法调了一个下午(加上参考别人写的代码[1])才调出来,从中发现了自己不少问题,希望以后多加练习的积累。

(1)C++有很多很好的容器模板,比如vector、stack,适当使用可以提高编程的效率。

(2)一定要自己亲手走完“写完整个程序->调通程序“整个步骤,保证程序健壮性(可以通过所有可能的不规则的输入,这点leetcode在线judge做的挺好的)。

(3)继续坚持每周一道leetcode。


参考:

http://blog.csdn.net/magisu/article/details/16998029


            
        
    

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
好的,以下是代码实现: ```c #include <stdio.h> #include <stdlib.h> #include <ctype.h> typedef struct ExpressionTree { int element; struct ExpressionTree* left_tree; struct ExpressionTree* right_tree; } ExpressionTree, *ExpressionTreeRoot; int evaluate(ExpressionTreeRoot T) { if (T->left_tree == NULL && T->right_tree == NULL) { return T->element; } else { int left_value = evaluate(T->left_tree); int right_value = evaluate(T->right_tree); switch (T->element) { case '+': return left_value + right_value; case '-': return left_value - right_value; case '*': return left_value * right_value; case '/': return left_value / right_value; default: return 0; } } } void in_fix(ExpressionTreeRoot T, bool is_root) { if (T == NULL) return; if (T->left_tree != NULL) { if (!is_root && is_leaf(T->left_tree)) { printf("("); } in_fix(T->left_tree, false); } printf("%c", T->element); if (T->right_tree != NULL) { in_fix(T->right_tree, false); if (!is_root && is_leaf(T->right_tree)) { printf(")"); } } } void reverse_polish(ExpressionTreeRoot T) { if (T == NULL) return; reverse_polish(T->left_tree); reverse_polish(T->right_tree); printf("%c", T->element); } bool is_leaf(ExpressionTreeRoot T) { return T->left_tree == NULL && T->right_tree == NULL; } int main() { ExpressionTreeRoot root = (ExpressionTree*)malloc(sizeof(ExpressionTree)); root->element = '+'; root->left_tree = (ExpressionTree*)malloc(sizeof(ExpressionTree)); root->left_tree->element = '*'; root->right_tree = (ExpressionTree*)malloc(sizeof(ExpressionTree)); root->right_tree->element = '-'; root->left_tree->left_tree = (ExpressionTree*)malloc(sizeof(ExpressionTree)); root->left_tree->left_tree->element = 3; root->left_tree->right_tree = (ExpressionTree*)malloc(sizeof(ExpressionTree)); root->left_tree->right_tree->element = 4; root->right_tree->left_tree = (ExpressionTree*)malloc(sizeof(ExpressionTree)); root->right_tree->left_tree->element = 5; root->right_tree->right_tree = (ExpressionTree*)malloc(sizeof(ExpressionTree)); root->right_tree->right_tree->element = 2; printf("Infix expression: "); in_fix(root, true); printf("\n"); printf("Reverse Polish notation: "); reverse_polish(root); printf("\n"); printf("Result: %d\n", evaluate(root)); return 0; } ``` 这个程序将建立一个如下所示的表达式树: ``` + / \ * - / \ / \ 3 4 5 2 ``` 并且提供了三个操作: - `in_fix`:以中缀方式输出表达式 - `reverse_polish`:以后缀方式输出表达式 - `evaluate`:计算整个表达式树的结果 你可以根据需要进行修改和扩展。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值