zoukankan      html  css  js  c++  java
  • 计算器程序,可以计算正实数范围内的任何数据的加减乘除括号,混合运算

    //计算器程序
    //可以计算正实数的四则混合运算
    //完成于07年6月3日 17:06
    #include<iostream>
    #include<sstream>
    #include<string>
    #include<iterator>
    #include<algorithm>
    #include<stack>
    using namespace std;
    const string operstr("+-*/()#");
                    //      +  -  *  /  (  )  #
    int gradation[7][7]={ 1, 1,-1,-1,-1, 1, 1,    //0: +
                          1, 1,-1,-1,-1, 1, 1,    //1: -
                          1, 1, 1, 1,-1, 1, 1,    //2: *
                          1, 1, 1, 1,-1, 1, 1,    //3: /
                         -1,-1,-1,-1,-1, 0, 3,  //4: (
                          1, 1, 1, 1, 3, 1, 1,    //5: )
                         -1,-1,-1,-1,-1, 3, 0    //6: #
    };
    int Precede(char a, char b)
    {
        int posa=find(operstr.begin(), operstr.end(), a) - operstr.begin();
        int posb=find(operstr.begin(), operstr.end(), b) - operstr.begin();
        return gradation[posa][posb];
    }
    double counte(double a,char o,double b)
    {
        switch(o)
        {
        case '+':
            return a+b;
            break;
        case '-':
            return a-b;
            break;
        case '*':
            return a*b;
            break;
        case '/':
            return a/b;
            break;
        }
        return 0;
    }
    void main()
    {
        cout<<"请输入表达式:";
        string s;
        cin>>s;
        s+='#';

        istringstream iss(s);    
        istream_iterator<char> input(iss);
        istream_iterator<char> end_input;

        stack<char> operate;            //操作符栈    
        stack<double> operand;            //操作数栈
        operate.push('#');

        while((input!=end_input&&*input!='#')||operate.top()!='#')
        {
            if(operstr.end()!=find(operstr.begin(),operstr.end(),*input))
            {
                //operate.push(*input++);                    //操作符进栈
                switch(Precede(operate.top(),*input))
                {
                case -1:                //栈顶元素优先权低
                    operate.push(*input++);
                    break;
                case 0:                    //脱去括号并接收下一个字符
                    operate.pop();
                    input++;
                    break;
                case 1:                    //退栈并将运算结果入栈
                    char o=operate.top();
                    operate.pop();
                    double b=operand.top();
                    operand.pop();
                    double a=operand.top();
                    operand.pop();

                    operand.push(counte(a,o,b));
                    break;
                }
            }
            else
            {                                                    
                string Snum;
                double Dnum=0;
                for(;operstr.end()==find(operstr.begin(),operstr.end(),*input);Snum+=*input++)
                    ;                                    //获得伪操作数
                istringstream ISSnum(Snum);
                ISSnum>>Dnum;                            //获得真操作数
                operand.push(Dnum);                        //操作数进栈
            }
        }
        cout<<"计算结果是: ";
        cout<<string(s.begin(),s.end()-1)<<"="<<operand.top()<<endl;//计算结果
    }

    上学时候写的。现在发现有人那这个做面试题。

  • 相关阅读:
    获得目标服务器中所有数据库名、表名、列名
    SQL Server 2008 安装SQLDMO.dll
    三层交换原理
    NAT地址转换原理全攻略
    C#中显/隐式实现接口及其访问方法
    As,is含义?using 语句
    c#泛型约束
    C#几个经常犯错误汇总
    C#--深入分析委托与事件
    markdown基础
  • 原文地址:https://www.cnblogs.com/vc60er/p/2690605.html
Copyright © 2011-2022 走看看