求前缀表达式的值(25)

这道题用到了栈,所以就用C++来做咯

当然C也可以做,不过就显得麻烦了。

/*--------------------------------------*/

我们把这道题分成几个部分

1. 输入部分 怎么判断输入的是一个运算符还是一个数?

2. 计算部分 前缀表达式如何计算?在什么情况下我们可以说前缀表达式有错,而报出一个"ERROR"?

首先创建了一个表达式栈expression用来存表达式的内容

第一部分的思路是这样的,每次从输入流获取一个字符串string

1.如果string是加减乘除,就把运算符push进表达式栈

2.如果string不是加减乘除,那string一定是数,就把str2double(string)的值push进站,str2double是我自己写的一个把字符串转换成double类型数的函数

经过了以上操作,表达式栈expression里就装好了表达式的内容

第二部分,开始计算咯。首先创建一个运算数栈num

1.如果expression.top是数,则把此数加入num,再expression.pop

2.如果expression.top是加减乘除,则取出num栈顶的两个元素,进行运算,再把运算结果加入num栈

什么时候应该报错呢?

1.  被除数是0时

2. expression.top是加减乘除,但是num栈里的元素少于两个,说明少了运算数,就像中缀表达式的(5+)*3一样,无法进行运算时

3. expression已经空了,可是num里的元素比两个还多,说明少了运算符,就像中缀表达式的(5 3)*3一样,无法进行运算时

最后,贴上代码

#include <iostream>
#include <cstdio>
#include <stack>
#include <string>
using namespace std;

typedef struct{
    char operation;
    double value;
}expr;

double str2double(string get);
void ERROR();

int main()
{
    stack<expr> expression;
    string get;
    do{
        cin >> get;
        if (get == "+" || get == "-" || get == "*" || get == "/"){
            expression.push({ get.at(0), 0.0 });
        }
        else{
            expression.push({ ‘\0‘, str2double(get) });
        }
    } while (getchar() != ‘\n‘);

    stack<double> num;
    while (expression.empty() != true){
        if (expression.top().operation == ‘\0‘){
            num.push(expression.top().value);
        }
        else{
            if (num.size() < 2){
                ERROR();
                return 0;
            }
            double a, b, c;
            b = num.top();
            num.pop();
            a = num.top();
            num.pop();
            if (expression.top().operation == ‘/‘ && a == 0){
                ERROR();
                return 0;
            }
            switch (expression.top().operation)
            {
            case‘+‘:c = b + a; break;
            case‘-‘:c = b - a; break;
            case‘*‘:c = b*a; break;
            case‘/‘:c = b / a; break;
            }
            num.push(c);
        }
        expression.pop();
    }
    if (num.size() >= 2){
        ERROR();
        return 0;
    }
    else{
        printf("%.1lf", num.top());
    }
}
double str2double(string get)
{
    auto begin = get.begin(), end = get.end();

    //符号处理
    bool negative = false;
    if (*begin == ‘-‘){
        negative = true;
        begin++;
    }
    else if (*begin == ‘+‘){
        begin++;
    }

    //绝对值计算
    double ret = 0;
    bool dot = false;
    double i = 10.0;
    while (begin != end){
        //逗号检测
        if (*begin == ‘.‘){
            dot = true;
            begin++;
            continue;
        }
        //逗号前
        if (dot == false){
            ret *= 10;
            ret += *begin - ‘0‘;
            begin++;
        }
        //逗号后
        else{
            ret += ((*begin) - ‘0‘) / i;
            i *= 10;
            begin++;
        }
    }

    //符号处理
    if (negative == true && ret != 0){
        ret = -ret;
    }

    return ret;
}
void ERROR()
{
    cout << "ERROR";
}

时间: 2024-11-01 16:41:14

求前缀表达式的值(25)的相关文章

02-线性结构3. 求前缀表达式的值(25)

02-线性结构3. 求前缀表达式的值(25) 时间限制 400 ms 内存限制 65536 kB 代码长度限制 8000 B 判题程序 Standard 算术表达式有前缀表示法.中缀表示法和后缀表示法等形式.前缀表达式指二元运算符位于两个运算数之前,例如2+3*(7-4)+8/4的前缀表达式是:+ + 2 * 3 - 7 4 / 8 4.请设计程序计算前缀表达式的结果值. 输入格式说明: 输入在一行内给出不超过30个字符的前缀表达式,只包含+.-.*.\以及运算数,不同对象(运算数.运算符号)之

pat02-线性结构3. 求前缀表达式的值(25)

02-线性结构3. 求前缀表达式的值(25) 时间限制 400 ms 内存限制 65536 kB 代码长度限制 8000 B 判题程序 Standard 算术表达式有前缀表示法.中缀表示法和后缀表示法等形式.前缀表达式指二元运算符位于两个运算数之前,例如2+3*(7-4)+8/4的前缀表达式是:+ + 2 * 3 - 7 4 / 8 4.请设计程序计算前缀表达式的结果值. 输入格式说明: 输入在一行内给出不超过30个字符的前缀表达式,只包含+.-.*.\以及运算数,不同对象(运算数.运算符号)之

求前缀表达式的值

算术表达式有前缀表示法.中缀表示法和后缀表示法等形式.前缀表达式指二元运算符位于两个运算数之前,例如2+3*(7-4)+8/4的前缀表达式是:+ + 2 * 3 - 7 4 / 8 4.请设计程序计算前缀表达式的结果值. 输入格式说明: 输入在一行内给出不超过30个字符的前缀表达式,只包含+.-.*.\以及运算数,不同对象(运算数.运算符号)之间以空格分隔. 输出格式说明: 输出前缀表达式的运算结果,精确到小数点后1位,或错误信息“ERROR”. 样例输入与输出: 序号 输入 输出 1 + +

7-21 求前缀表达式的值

7-21 求前缀表达式的值(25 分) 算术表达式有前缀表示法.中缀表示法和后缀表示法等形式.前缀表达式指二元运算符位于两个运算数之前,例如2+3*(7-4)+8/4的前缀表达式是:+ + 2 * 3 - 7 4 / 8 4.请设计程序计算前缀表达式的结果值. 输入格式: 输入在一行内给出不超过30个字符的前缀表达式,只包含+.-.*.\以及运算数,不同对象(运算数.运算符号)之间以空格分隔. 输出格式: 输出前缀表达式的运算结果,保留小数点后1位,或错误信息ERROR. 输入样例: + + 2

3-07. 求前缀表达式的值(25) (ZJU_PAT数学)

题目链接:http://pat.zju.edu.cn/contests/ds/3-07 算术表达式有前缀表示法.中缀表示法和后缀表示法等形式.前缀表达式指二元运算符位于两个运算数之前,例如2+3*(7-4)+8/4的前缀表达式是:+ + 2 * 3 - 7 4 / 8 4.请设计程序计算前缀表达式的结果值. 输入格式说明: 输入在一行内给出不超过30个字符的前缀表达式,只包含+.-.*.\以及运算数,不同对象(运算数.运算符号)之间以空格分隔. 输出格式说明: 输出前缀表达式的运算结果,精确到小

7-21 求前缀表达式的值(25 分)

前缀表达式的计算机求值:从右至左扫描表达式,遇到数字时,将数字压入堆栈,遇到运算符时,弹出栈顶的两个数,用运算符对它们做相应的计算(栈顶元素 op 次顶元素),并将结果入栈:重复上述过程直到表达式最左端,最后运算得出的值即为表达式的结果.例如前缀表达式"- × + 3 4 5 6":(1) 从右至左扫描,将6.5.4.3压入堆栈:(2) 遇到+运算符,因此弹出3和4(3为栈顶元素,4为次顶元素,注意与后缀表达式做比较),计算出3+4的值,得7,再将7入栈:(3) 接下来是×运算符,因此

【Zhejiang University PATest】02-3. 求前缀表达式的值

算术表达式有前缀表示法.中缀表示法和后缀表示法等形式.前缀表达式指二元运算符位于两个运算数之前,例如2+3*(7-4)+8/4的前缀表达式是:+ + 2 * 3 - 7 4 / 8 4.请设计程序计算前缀表达式的结果值. 输入格式说明: 输入在一行内给出不超过30个字符的前缀表达式,只包含+.-.*.\以及运算数,不同对象(运算数.运算符号)之间以空格分隔. 输出格式说明: 输出前缀表达式的运算结果,精确到小数点后1位,或错误信息“ERROR”. 样例输入与输出: 序号 输入 输出 1 + +

PAT 线性结构3. 求前缀表达式的值 栈的应用

题目链接: 前缀表达式求值 题解: 同后缀表达式求值思路: 遇到数值则入栈,遇到操作符则从栈中取出最上面的两个数值进行操作,再将结果入栈,最后得到的栈顶元素则为答案. 前缀表达式从后往前遍历即可. 代码: #include<iostream> #include<cstdio> #include<cstring> #include<stack> using namespace std; int op(char a) { if(a=='+'||a=='-'||a

【PAT】2-3 求前缀表达式的值

求值方法: 对于一个前缀表达式的求值而言,首先要从右至左扫描表达式,从右边第一个字符开始判断,如果当前字符是数字则一直到数字串的末尾再记录下来,如果是运算符,则将右边离得最近的两个“数字串”作相应的运算,以此作为一个新的“数字串”并记录下来.一直扫描到表达式的最左端时,最后运算的值也就是表达式的值.例如,前缀表达式“- 1 + 2 3“的求值,扫描到3时,记录下这个数字串,扫描到2时,记录下这个数字串,当扫描到+时,将+右移做相邻两数字串的运算符,记为2+3,结果为5,记录下这个新数字串,并继续