题目信息:

http://acm.nyist.net/JudgeOnline/problem.php?

pid=128

+ 2 * + 3 4 5的值就是 37,详见输入输出。

输入
有多组測试数据,每组測试数据占一行,随意两个操作符之间。随意两个操作数之间,操作数与操作符之间都有一个空格。输入的两个操作数可能是小数,数据保证输入的数都是正数。而且都小于10,操作数数目不超过500。

以EOF为输入结束的标志。
输出
对每组数据,输出该前缀表达式的值。

输出结果保留两位小数。

例子输入
+ 2 * + 3 4 5
+ 5.1 / 3 7
例子输出
37.00
5.53

题目分析:

用两个栈进行存下数字和操作,进行计算,我刚開始想的是,每当连续输入两个数即可进行计算,并将结果压入数字栈中,而且操作时。应该保证后出栈的数字在前。先出栈的在后,这样能够保证-、/的结果。

。。。。哎。不知道为什么一直Wa,最后看看别人打代码。这题能够从后往前计算。遇到操作符进行计算即可。此题须要注意就是字符串到数字的转换。

AC代码:

#include<iostream>
#include<cstdio>
#include<map>
#include<cstring>
#include<string>
#include<algorithm>
#include<queue>
#include<vector>
#include<stack>
#include<cstdlib>
#include<cctype>
#include<cstring>
#include<cmath>
using namespace std;
char str[1005];
stack<double> dt;
int start; void vol(){
int i=0,k=0;
char a[15],b[15];
for(;str[start]!=' ';start--){
a[k++]=str[start];
}
start--;//去掉数字后面的空格
a[k]='\0';
//strrev();此函数不能用
for(i=0;i<k/2;i++){
char c=a[i];
a[i]=a[k-1-i];;
a[k-1-i]=c;
}
dt.push(atof(a));
}
double YunSuan(){
double a,b;
while(start!=-2){
switch (str[start]){
case '+':
a=dt.top(); dt.pop();
b=dt.top(); dt.pop();
dt.push(b+a);start-=2;//去掉该字符和字符后面的空格
break;
case '-':
a=dt.top(); dt.pop();
b=dt.top(); dt.pop();
dt.push(a-b);start-=2;
break;
case '*':
a=dt.top(); dt.pop();
b=dt.top(); dt.pop();
dt.push(a*b);start-=2;
break;
case '/':
a=dt.top(); dt.pop();
b=dt.top(); dt.pop();
dt.push(a/b);start-=2;
break;
default: vol();
}
}
return dt.top();
}
int main()
{
while(gets(str)){
start=strlen(str)-1;
printf("%.2lf\n",YunSuan());
}
return 0;
}

我的代码:

int main()
{
string str;
int i,k;
double a,b;
while(getline(cin,str)){
stack<double> dt;
stack<char> ct;
i=-1; k=0;
while(i!=str.size()){
++i;
if(str[i] == ' ') ++i;
if(str[i] >= '0' && str[i] <= '9'){
string res; double temp;
while(i != str.size() && str[i] != ' ')
res += str[i++];
sscanf(res.c_str(), "%lf", &temp);
//cout<<temp<<endl;
dt.push(temp),++k;
//++k;
}
if(str[i]=='+'||str[i]=='-'||str[i]=='*'||str[i]=='/'){
ct.push(str[i++]);
k=0;
}
if(k==2&&dt.size()>1){
a=dt.top();
dt.pop();
b=dt.top();
dt.pop();
char c=ct.top();
ct.pop();
if(c=='+') dt.push(b+a);
if(c=='-') dt.push(b-a);
if(c=='*') dt.push(b*a);
if(c=='/') dt.push(b/a);
k=1;
}
}
while(dt.size()>1&&ct.size()){//计算最后一个
a=dt.top();
dt.pop();
b=dt.top();
dt.pop();
char c=ct.top();
ct.pop();
if(c=='+') dt.push(b+a);
if(c=='-') dt.push(b-a);
if(c=='*') dt.push(b*a);
if(c=='/') dt.push(b/a);
}
int k=1;
if(ct.size()&&ct.top()=='-') k=-1;
printf("%.2lf\n",k*dt.top());
}
return 0;
}


NYOJ128 前缀式计算(栈的运用)的更多相关文章

  1. NYOJ128 前缀式计算 【栈】

    前缀式计算 时间限制:1000 ms  |  内存限制:65535 KB 难度:3 描写叙述 先说明一下什么是中缀式: 如2+(3+4)*5这样的我们最常见的式子就是中缀式. 而把中缀式按运算顺序加上 ...

  2. NYOJ128前缀式计算

    前缀式计算 时间限制:1000 ms  |  内存限制:65535 KB 难度:3   描述 先说明一下什么是中缀式: 如2+(3+4)*5这种我们最常见的式子就是中缀式. 而把中缀式按运算顺序加上括 ...

  3. NYOJ 128 前缀式计算

    前缀式计算 时间限制:1000 ms  |  内存限制:65535 KB 难度:3   描述 先说明一下什么是中缀式: 如2+(3+4)*5这种我们最常见的式子就是中缀式. 而把中缀式按运算顺序加上括 ...

  4. 前缀式计算 nyoj

    题目描述 先说明一下什么是中缀式: 如2+(3+4)*5这种我们最常见的式子就是中缀式. 而把中缀式按运算顺序加上括号就是:(2+((3+4)*5)) 然后把运算符写到括号前面就是+(2 *( +(3 ...

  5. nyoj-----前缀式计算

    前缀式计算 时间限制:1000 ms  |           内存限制:65535 KB 难度:3   描述 先说明一下什么是中缀式: 如2+(3+4)*5这种我们最常见的式子就是中缀式. 而把中缀 ...

  6. NYOJ--128--前缀式计算(表达式求值)

    前缀式计算 时间限制:1000 ms  |  内存限制:65535 KB 难度:3   描述 先说明一下什么是中缀式: 如2+(3+4)*5这种我们最常见的式子就是中缀式. 而把中缀式按运算顺序加上括 ...

  7. 大数据入门第十六天——流式计算之storm详解(一)入门与集群安装

    一.概述 今天起就正式进入了流式计算.这里先解释一下流式计算的概念 离线计算 离线计算:批量获取数据.批量传输数据.周期性批量计算数据.数据展示 代表技术:Sqoop批量导入数据.HDFS批量存储数据 ...

  8. 搜索广告与广告网络Demand技术-流式计算平台

    流式计算平台-Storm 我们以Storm为例来看流式计算的功能是什么. 下面内容引用自大圆的博客.在Storm中,一个实时应用的计算任务被打包作为Topology发布,这同Hadoop的MapRed ...

  9. 流式计算与计算抽象化------《Designing Data-Intensive Applications》读书笔记15

    上篇的内容,我们探讨了分布式计算中的MapReduce与批处理.所以本篇我们将继续探索分布式计算优化的相关细节,并且分析MapReduce与批处理的局限性,看看流式计算是否能给我们在分布式计算层面提供 ...

随机推荐

  1. android-Java SoftReference,WeakReference,Direct Reference简介

    主要部分: SoftReference(软引用)是java中一个用来实现缓存内容的类.通过此类,可以观察某对象什么时候会被垃圾收集的执行绪清除.被 Soft Reference 指到的对象,即使没有任 ...

  2. keil mdk中如何确保某一段程序不被优化掉

    使用mdk编程,假如有一个有用的函数你定义了但是没有显式的调用,mdk在默认方式下,将会把这个函数从整个程序总删除掉,以节省ROM. 比如,你在ROM的0x00002000处定位了一个函数,假设为vo ...

  3. RDLC报表 在WinForm里运行出现 未能加载文件或程序集 Microsoft.ReportViewer.WinForms, Version=11.0.0.0 System.IO.FileNotFoundException

    原文:RDLC报表 在WinForm里运行出现 未能加载文件或程序集microsoft.reportviewer.winforms 推荐以下方案二 做一下记录顺便帮助一下遇到问题的朋友. 做RDLC报 ...

  4. Xlint以及Java Lint 选项

    Java Lint 选项 Java 编译器的选项包括所谓的标准选项和非标准选项.标准选项是指在当前版本的开发环境中支持,且在未来版本中也将被支持的选项.常用的标准选项比如 -classpath 以及 ...

  5. CC++初学者编程教程(4) 安装Oracle12c于Windows Sever2012

    我们开启虚拟机 Windows Sever2012启动中. 3.看到WindowsSever2012的桌面. 我们解压缩两个文件, winx64_12c_database_1of2.zip,winx6 ...

  6. poj2909 || poj2262

    #include <stdio.h> #include <stdlib.h> #include<math.h> int isPri(int a, int b) { ...

  7. Guava缓存器源码分析——删除消息

    Guava缓存器的删除消息机制 测试代码——             LoadingCache<String, Integer> cache = CacheBuilder.newBuild ...

  8. 小窍门:变更Windows Azure Websites自带的node.exe版本

    这几天在玩node.js.Azure Websites天然支持node.js(还支持.net, php和python).   它对nodejs支持的原理是: IIS充当Web服务器,接收所有的请求,而 ...

  9. php汉字截取

    /** * 截取HTML,并自动补全闭合 * @param $html * @param $length * @param $end */ function subHtml($html,$length ...

  10. Javaweb整合mongo和kettle6.0的环境配置

    为了编译能通过,maven需要加入仓库地址以及一些必须要的包的依赖情况: pentaho中央仓库: 在properties里面配置版本号: <kettle.version>6.0.0.0- ...