NYOJ 35表达式求值

表达式求值

时间限制:3000 ms | 内存限制:65535 KB
难度:4
描述
ACM队的mdd想做一个计算器,但是,他要做的不仅仅是一计算一个A+B的计算器,他想实现随便输入一个表达式都能求出它的值的计算器,现在请你帮助他来实现这个计算器吧。
比如输入:“1+2/4=”,程序就输出1.50(结果保留两位小数)
输入
第一行输入一个整数n,共有n组测试数据(n<10)。
每组测试数据只有一行,是一个长度不超过1000的字符串,表示这个运算式,每个运算式都是以“=”结束。这个表达式里只包含+-*/与小括号这几种符号。其中小括号可以嵌套使用。数据保证输入的操作数中不会出现负数。
数据保证除数不会为0
输出
每组都输出该组运算式的运算结果,输出结果保留两位小数。
样例输入
2
1.000+2/4=
((1+2)*5+1)/4=
样例输出
1.50
4.00


/*表达式计算思路:从左到右遍历中缀表达式中的每个数字和符号,若是数字则直接压入数据栈中,若是符号(左括号直接入符号栈),则判断其与栈顶符号的优先级,是右括号或优先级低于栈顶符号,则栈(符号栈即数据栈)中的元素依次出栈并计算,直到遇到左括号或栈顶元素优先级小于该符号压入符号栈为止,最后符号栈依次出栈计算直至符号为空。 
*/ #include "stdio.h"
#include "ctype.h"
#include "stack"
#define maxn 1000+10using namespace std;char buf[maxn];
stack<char> op;		//符号队列 
stack<double> n; //得到操作符的优先级 
int getValue(char c){	if('('==c) return 0;		if('+'==c || '-'==c) return 1;if('*'==c || '/'==c) return 2;	
}double calc(double a,double b,char c)
{
//	printf("出栈操作:%f %c %f \n",a,c,b);switch(c){case '+': return (a+b);case '-': return (a-b);case '*': return (a*b);case '/': return (a/b);}
}//操作符出栈,即进行计算一次 
void pull()
{	double a,b;if(n.size()>1 && !op.empty()){b=n.top(); n.pop();a=n.top(); n.pop();n.push(calc(a,b,op.top())); //printf("%d:出栈结果入栈!\n",n.size()); op.pop();//	printf("符号:%d  数字:  %d 出栈完毕!\n",op.size(),n.size());}
}int main()
{		int N,i;double d;char c;scanf("%d",&N);while(N--){		scanf("%s",buf); i=0;while(1){if(isalnum(buf[i])){sscanf(buf+i,"%lf",&d);n.push(d);// printf("%d:数字入栈:%lf\n",n.size(),d);while(isalnum(buf[i]) || '.'==buf[i]) i++;				}c=buf[i++];										if('='==c || '\0'==c) break; 			if('('==c){op.push(c); // printf("(入栈\n");}else if(')'==c){while(!op.empty()){if('('==op.top()) {op.pop(); break;	}pull();}}else{//注意先后顺序,不为空才能进行op.top()操作 while( !op.empty()  && getValue(c)<=getValue(op.top()))	 pull();op.push(c); //printf("%d:符号入栈:%c \n",op.size(),c);}								}														while(!op.empty())	pull();		printf("%.2lf\n",n.top()); while(!n.empty())	n.pop();		} 		return 0;
}


本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/374009.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Java EE6 CDI,命名组件和限定符

Java EE6的最大承诺之一就是简化了依赖注入的使用。 他们做到了&#xff0c;使用CDI 。 CDI代表Java EE的上下文和依赖注入&#xff0c;它提供了一个基础集&#xff0c;用于在企业应用程序中应用依赖注入。 在CDI之前&#xff0c;EJB 3还引入了依赖注入&#xff0c;但这有点基础…

c#获取当前目录的一些方法

【内容来源地址】&#xff1a;http://www.cnblogs.com/marcozh/archive/2008/10/19/1314667.html Assembly myAssembly Assembly.GetEntryAssembly(); string path myAssembly.Location; DirectoryInfo dr new DirectoryInfo(path); pathd…

linux里的进程简介

/sbin/init 内核启动的第一个用户级进程,引导用户空间服务 [kthreadd] 内核线程管理[migration/0] 用于进程在不同的CPU间迁移[ksoftirqd/0] 内核调度/管理第0个CPU软中断的守护进程[migration/1] 管理多核心[ksoftirqd/1] 内核调度/管…

python画画bup_Python中的高效Vector / Point类

实现高效的Vector / Point类的最佳方法是什么(甚至更好&#xff1a;是否有一个),可以在Python 2.7和3.x中使用&#xff1f;我找到了the blender-mathutils,但它们似乎只支持Python 3.x.然后是this Vector class,使用numpy,但它只是一个3D矢量.使用具有静态属性(x和y)的像kivy’…

CSDN 编程挑战——《coder的计算器》

coder的计算器 题目详情: coder现在已经上初中&#xff0c;也会用计算器实现 ,-,*,/和幂运算^了&#xff0c;但他觉得市场那些计算器太繁琐了&#xff0c;有很多他不认识的符号&#xff0c;所以他现在很想要能计算带括号的 ,-,*,/和幂运算^的混合表达式就可以了&#xff0c;你…

OpenShift Express:部署Java EE应用程序(支持AS7)

在过去的几年中&#xff0c;我越来越听到有关“云”服务的信息。 最初&#xff0c;我并不是很想尝试一下。 但是几个月后&#xff08;一年&#xff1f;&#xff09;&#xff0c;我决定看看这是怎么回事。 我从事Java EE开发已经超过7年了&#xff0c;所以我决定看看将Java EE应…

07 总结ProgressDialog 异步任务

1,ProgressDialog> //使用对象 设置标题 progressDialog.setTitle("标题"); //设置图标 progressDialog.setIcon(R.drawable.ic_launcher); //设置展示的内容 progressDialog.setMessage(&q…

python函数封装计算n运算_在Python里面怎么可以运算出999999999**999999999,求思路?...

>>> 999999999 * math.log(999999999, 2) / 8 / 1024 ** 33.480509950621777所以这个数字本身就差不多需要3.5GB内存&#xff0c;考虑到计算过程中需要存储临时结果&#xff0c;还需要翻个两三倍吧而Python中的long可以到多少呢&#xff1a;#define MAX_LONG_DIGITS \…

C++中const关键字的使用总结

const是不变的意思&#xff0c;在C程序中&#xff0c;经常用const来限制对一个对象的操作: 1.1 const变量 例如&#xff1a; const int n3; 则这个变量的值不能改变&#xff0c;即不能对变量赋值。 1.2 const参数 出现在函数参数中的const表示在函数体中不能对这个参数做修改…

php封装redis负载均衡类

$array array( master > array( "redis://127.0.0.1:6379?timeout1", ), slave > array( "redis://127.0.0.1:6479?timeout1", "redis://127.0.0.1:6579?timeout1", ) ); $redis R…

我今天对JavaFX的了解

如果您没有听说过&#xff0c;JavaFX 2是Java的新Desktop / web / client框架。 自JavaFX 1以来&#xff0c;它已经进行了相当大的改动&#xff08;坦率地说&#xff0c;效果并不那么令人印象深刻&#xff09;。 自定义脚本语言已经淘汰了&#xff0c;您可以使用标准Java和基于…

怎么解决xp系统不能安装NET Framework4.0?

.net 4.0安装不上解决方法&#xff1a; 引用 9 楼 MoreQuestion 的回复: 全部都不行&#xff01;就是用360软件管家安装那个就可以了。用了楼主的方法&#xff0c;果然可行啊 1.先安装wic。 2.用360安装.net40 本帖最后由 不懂 于 2014-6-6 00:56 编辑Windows Server 2003 如何…

C++内联(inline)函数

内联函数 内联函数是一种特殊类型的函数&#xff0c;内联函数在定义或声明时前面加上“inline”关键字。比如&#xff1a; inline int max(int a,int b) { return (a>b)?a:b; } 内联&#xff08;inline&#xff09;是内联扩展&#xff08;inline expansion&#xff09;的简…

我的python学习笔记全集_记录我的Python学习笔记

不想再像以前那样&#xff0c;什么都从头开始学习语法、总结语法&#xff0c;这样反而会过分纠结于语法&#xff0c;耽误了开发&#xff0c;毕竟语言的主要属性是工具&#xff0c;次要的属性是语言本身。所以还是先熟练使用语言去进行开发&#xff0c;等足够熟悉了&#xff0c;…

HDU 5794:A Simple Chess(Lucas + DP)

题目链接&#xff1a;http://acm.split.hdu.edu.cn/showproblem.php?pid5794 题意&#xff1a;让一个棋子从&#xff08;1,1&#xff09;走到&#xff08;n&#xff0c;m&#xff09;&#xff0c;要求像马一样走日字型并只能往右下角走。里面还有r个障碍点不能经过或者到达&am…

php源码分析之PHPAPI宏的作用

在PHP源码中&#xff0c;我们经常会看到很多函数前面有个PHPAPI&#xff0c;但这是什么呢&#xff1f; 于是我在php源码/main/php.h中找到了它的定义 #ifdef PHP_WIN32 # include "tsrm_win32.h" # include "win95nt.h" # ifdef PHP_EXPORTS # …

15分钟内开始使用Amazon Web Services和全自动资源调配

在等待一个新项目时&#xff0c;我想学习一些有用的东西。 而且由于在许多项目中我们需要评估和测试正在开发的应用程序的性能&#xff0c;而很少有足够的硬件来生成实际负载&#xff0c;因此我决定学习更多有关按需在云中按需配置虚拟机的知识&#xff0c;即Amazon Web Servic…

解析JVM内存区域组成

在方法&#xff08;代码块&#xff09;中定义一个变量时&#xff0c;java就在栈中为这个变量分配JVM内存空间&#xff0c;当超过变量的作用域后&#xff0c;java会自动释放掉为该变量所分配的JVM内存空间&#xff1b;而在堆中分配的JVM内存由java虚拟机的自动垃圾回收器来管理。…

python打开浏览器后带cookie_Python爬虫使用浏览器的cookies:browsercookie

很多用Python的人可能都写过网络爬虫&#xff0c;自动化获取网络数据确实是一件令人愉悦的事情&#xff0c;而Python很好的帮助我们达到这种愉悦。然而&#xff0c;爬虫经常要碰到各种登录、验证的阻挠&#xff0c;让人灰心丧气(网站&#xff1a;天天碰到各种各样的爬虫抓我们网…

VS插件开发

参考资料: VS插件开发 - 个性化VS IDE编辑器 自己动手编写一个VS插件&#xff08;一&#xff09; VS Addin插件基本开发入门 VS Addin插件配置、部署 转载于:https://www.cnblogs.com/wangwangfei/p/5830081.html