码迷,mamicode.com
首页 > 其他好文 > 详细

20-表达式求值

时间:2017-08-26 04:54:44      阅读:183      评论:0      收藏:0      [点我收藏+]

标签:正整数   char   tac   pop   sum   name   结果   运算   题目   

/*
表题目内容:

 输入一个由数字、+,-,*,/ 组成的算术表达式,求其值。

输入描述

一个表达式,其中每个运算数为正整数

输出描述

计算结果,保留2位小数

输入样例

1+12*3-4/2

输出样例

35.00
 
*/
#include <iostream>
#include <cstdio>
#include <stack>
using namespace std;
    
int fu(char ch){
    if(ch == ‘#‘ || ch == ‘=‘)
        return 0;
    if(ch == ‘-‘ || ch == ‘+‘)
        return 1;
    if(ch == ‘*‘ || ch == ‘/‘)
        return 2;    
}

void qiuzhi(string str){
    int i = 0;
    stack <double>s;  //数字栈
    stack <char>f;    //符号栈    优先级低的高的进栈,比栈顶低,则弹出栈顶的进行运算,直到比栈顶高才进栈
    f.push(‘#‘);
    while(str[i]){
        int a = 0, flag = 0;
        while(str[i] >= ‘0‘ && str[i] <= ‘9‘){
            a = a * 10 + str[i] - ‘0‘;
            i++;
            flag = 1;
        }
        if(flag)
            s.push(a);
        if(fu(str[i]) >= fu(f.top())){
            f.push(str[i]);  
            i++;    
        }
        int flag1 = 0;
        while(fu(str[i]) < fu(f.top())){
            char ch = f.top();
            f.pop();
            double c, d, e;
            c = s.top(); s.pop();
            d = s.top(); s.pop();
            if(ch == ‘-‘)
                e = d - c;
            else if(ch == ‘+‘)
                e = d + c;            
            else if(ch == ‘*‘)
                e = d * c;
            else if(ch == ‘/‘)
                e = d * 1.0 / c;        
            s.push(e);
//            f.push(str[i]);    
            flag1 = 1;
        }
        if(flag1){
            if(str[i] == ‘=‘){
                double sum = s.top();
                printf("%.2lf", sum);
//                cout << sum;
                return;
            }
            f.push(str[i]);
            i++;
        }
    }
}

int main(){
    string str;
    cin >> str;
    str += ‘=‘;
    qiuzhi(str);    
//    cout << str;
    return 0;
}

20-表达式求值

标签:正整数   char   tac   pop   sum   name   结果   运算   题目   

原文地址:http://www.cnblogs.com/zhumengdexiaobai/p/7429758.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!