02-3. 求前缀表达式的值(25)
2015-01-28 15:41
351 查看
#include <cstdio> #include <cstring> #include <iostream> #include <algorithm> #include <stack> using namespace std; char s[47]; stack<double>ss; int is_op(char c) { if(c=='+' || c=='-' || c=='*' || c=='/') return 1; return 0; } int main() { while(gets(s)) { while(!ss.empty())//清空 { ss.pop(); } int len = strlen(s); int cc = 1; double tsum = 0; int flag = 0;//标记是否出现零作为除数的情况 for(int i = len-1; i >= 0; i--) { if(s[i]>='0' && s[i]<='9') { tsum+=(s[i]-'0')*cc; cc*=10; } else if(s[i] == '.')//小数 { tsum = tsum/(cc*1.0); cc = 1; } else if((s[i]=='+'||s[i]=='-') && tsum!=0) { if(s[i] == '+') { ss.push(tsum); i--;//跳过下一个空格 continue; } else { tsum = -tsum; ss.push(tsum); i--;//跳过下一个空格 continue; } } else if(s[i] == ' ')//其中一个运算数已经统计完 { ss.push(tsum); tsum = 0; cc = 1; continue; } else if(is_op(s[i]))//如果是运算符 { double a = ss.top(); ss.pop(); double b = ss.top(); ss.pop(); double tt = 0; if(s[i] == '+') tt = a+b; else if(s[i] == '-') tt = a-b; else if(s[i] == '*') tt = a*b; else if(s[i] == '/') { if(b == 0) { flag = 1; break; } tt = a/b; } ss.push(tt); i--;//跳过下一个空格 } } /*int k = 0;//记录最后栈内还剩有的数字有多少个,有多个则ERROR int lenn = ss.size(); double tt; for(int i = 0; i < lenn; i++) { tt = ss.top(); ss.pop(); if(!is_op(tt)) { k++; } } if(flag != 1) printf("%.1lf\n",tt);*/ if(flag != 1) printf("%.1lf\n",ss.top()); else printf("ERROR\n"); } return 0; }
相关文章推荐
- PAT 02-3. 求前缀表达式的值(25) Python
- PAT 02-3. 求前缀表达式的值(25)
- 02-线性结构3. 求前缀表达式的值(25)
- 02-线性结构3. 求前缀表达式的值(25)
- 【Zhejiang University PATest】02-3. 求前缀表达式的值
- 02-线性结构3. 求前缀表达式的值(25)
- PAT 数据结构 02-线性结构3. 求前缀表达式的值(25)
- 02-线性结构3. 求前缀表达式的值(25)
- 02-线性结构3. 求前缀表达式的值(25)
- [数据结构]7-21 求前缀表达式的值(25 分)
- 中国大学MOOC-数据结构基础习题集、02-3、求前缀表达式的值
- 3-07. 求前缀表达式的值(25) (ZJU_PAT数学)
- 求前缀表达式的值(25)
- PAT1023. 求前缀表达式的值(25)
- 3-07. 求前缀表达式的值(25)
- 3-2 求前缀表达式的值(25 分)
- 3-07. 求前缀表达式的值(25)
- 7-19 求前缀表达式的值(25 分)---栈的运用
- PAT 1130. Infix Expression (25) 前缀表达式、树的中序遍历
- 3-07. 求前缀表达式的值(25) (ZJU_PAT数学)