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

题目链接:

前缀表达式求值

题解:

同后缀表达式求值思路:

遇到数值则入栈,遇到操作符则从栈中取出最上面的两个数值进行操作,再将结果入栈,最后得到的栈顶元素则为答案。

前缀表达式从后往前遍历即可。

代码:

#include<iostream>
#include<cstdio>
#include<cstring>
#include<stack>
using namespace std;
int op(char a)
{
    if(a=='+'||a=='-'||a=='*'||a=='/')
        return 1;
    return 0;
}
int main()
{
    char str1[105];
    int len,i,flag=0,k=1,flagg=0;
    double s=0;
    gets(str1);
    len=strlen(str1);
    stack<double>q;
    for(i=len-1; i>=0; i--)      //从后往前
    {
        if(str1[i]==' ')
           {
               if(s!=0)
                q.push(s);
               flag=0,s=0,k=1;
           }
        else if(flag==0&&str1[i]>='0'&&str1[i]<='9')
            flag=1,s=str1[i]-'0',k=k*10;
        else if(flag==1&&str1[i]>='0'&&str1[i]<='9')
            s=s+(str1[i]-'0')*k,k=k*10;
        else if(flag==1&&str1[i]=='-')
            s=-s;
         else if(flag==1&&str1[i]=='.')
            s=s/100.0,k=1;
        else if(flag==0&&op(str1[i]))
        {
            double a,b,ans;
            a=q.top();
            q.pop();
            b=q.top();
            q.pop();
            if(str1[i]=='+')
                ans=a+b;
            else if(str1[i]=='-')
                ans=a-b;
            else if(str1[i]=='*')
                ans=a*b;
            else if(str1[i]=='/')
                {
                    if(b==0)            //除数为0则是ERROR
                        flagg=1;
                    ans=a/b;
                }
            q.push(ans);
        }
    }
    if(q.empty())                    //最后一组样例
        q.push(s);
    if(flagg==1||q.size()>1)
        printf("ERROR\n");
    else
        printf("%.1lf\n",q.top());
    return 0;
}
时间: 2024-07-29 21:14:38

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

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

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

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

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

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

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) 接下来是×运算符,因此

求前缀表达式的值(25)

这道题用到了栈,所以就用C++来做咯 当然C也可以做,不过就显得麻烦了. /*--------------------------------------*/ 我们把这道题分成几个部分 1. 输入部分 怎么判断输入的是一个运算符还是一个数? 2. 计算部分 前缀表达式如何计算?在什么情况下我们可以说前缀表达式有错,而报出一个"ERROR"? 首先创建了一个表达式栈expression用来存表达式的内容 第一部分的思路是这样的,每次从输入流获取一个字符串string 1.如果string