zoukankan      html  css  js  c++  java
  • 逆波兰表达式改写(C++)

    #include<iostream>
    #include<cstring>
    
    using namespace std;
    
    class EV{
        public:
            EV(const int &vR, const int& vN)
            {
                result = vR;
                n =vN;
            }
            EV(){}
            int getResult() const
            {
                return result;
            }
            int getN() const
            {
                return n;
            }
            void setResult(const int& r)
            {
                result = r;
            }
            void setN(const int& N)
            {
                n = N;
            }
        private:
            int result, n ;
    
    };
    
    EV evaluate(const char* x)
    {
        EV ev(0,0);
        EV v1, v2;
        if(*x == 0) return ev;
        if(x[0] >= '0' && x[0] <= '9')
        {
            ev.setResult(x[0] - '0') ;
            ev.setN(1);
            return ev;
        }
        v1 = evaluate(x + 1);
        v2 = evaluate(x + 1 + v1.getN());
        if(x[0] == '+') ev.setResult(v1.getResult() + v2.getResult());
        if(x[0] == '*') ev.setResult(v1.getResult() * v2.getResult());
        if(x[0] == '-') ev.setResult(v1.getResult() - v2.getResult());
        ev.setN(  1 + v1.getN() + v2.getN());
        return ev;
    }
    
    int main(int argc, char* argv[])
    {
        string s = "-+3*5+261";
        const EV &ev = evaluate((char*)(s.c_str()));
        int res = ev.getResult();
        cout << res << endl;
        return 0;
    }
  • 相关阅读:
    关于栈部分知识点
    面向对象--四则运算
    转型第一步
    输入输出文件版本——计算题
    作业二
    2017《面向对象程序设计》课程作业一
    第四次作业
    light oj 1079
    Light oj 1080
    Codeforces 486B OR in Matrix【水题】
  • 原文地址:https://www.cnblogs.com/fourmi/p/12531686.html
Copyright © 2011-2022 走看看