title: 表达式求值 第九届省赛 nyoj 1272
tags: [栈,数据结构]
题目链接
描述
假设表达式定义为: 1. 一个十进制的正整数 X 是一个表达式。 2. 如果 X 和 Y 是 表达式,则 X+Y, XY 也是表达式; *优先级高于+. 3. 如果 X 和 Y 是 表达式,则 函数 Smax(X,Y)也是表达式,其值为:先分别求出 X ,Y 值的各位数字之和,再从中选最大数。 4.如果 X 是 表达式,则 (X)也是表达式。 例如: 表达式 12(2+3)+Smax(333,220+280) 的值为 69。 请你编程,对给定的表达式,输出其值。
输入
【标准输入】 第一行: T 表示要计算的表达式个数 (1≤ T ≤ 10) 接下来有 T 行, 每行是一个字符串,表示待求的表达式,长度<=1000
输出
【标准输出】 对于每个表达式,输出一行,表示对应表达式的值。
样例输入
3
12+2*3
12*(2+3)
12*(2+3)+Smax(333,220+280)
样例输出
18
60
69
分析:
跟普通的表达式求值得算法没有什么大的区别,也是把中缀表达式转换为后缀表达式,然后用后缀表达式来求解。吧Smax也看做一种与加减乘除一样的运算,而他的优先级是最大的。
代码:
#include<bits/stdc++.h>
using namespace std;
char in[1001];///中缀
char post[1001];///后缀
int pri[200];///优先级
bool isNum(char a)///判断是不是数字
{
if(a>='0'&&a<='9')
return true;
return false;
}
void zhuan()///中缀转后缀
{
stack<char>op;
op.push('=');
int k=0,k1=0;
for(int i=0; in[i]!='\0'; i++)
{
if(in[i]=='m'||in[i]=='a'||in[i]=='x')///'S'也当作一个运算符了,这样的话就不用处理他们了
continue;
if(isNum(in[i]))
{
post[k++]=in[i];
k1++;
}
else
{
if(k1!=0)///有数字的话,就把数字分割开
{
post[k++]=' ';
k1=0;
}
if(in[i]==',')continue;///跳过,不用处理
if(in[i]=='(')
op.push(in[i]);
else if(in[i]==')')
{
while(op.top()!='(')
{
post[k++]=op.top();
op.pop();
}
op.pop();
}
else
{
while(pri[op.top()]>=pri[in[i]])
{
post[k++]=op.top();
op.pop();
}
op.push(in[i]);
}
}
}
while(op.top()!='=')
{
post[k++]=op.top();
op.pop();
}
post[k]='\0';
}
int Smax(int a,int b)///定义Smax的运算
{
int suma=0;
while(a)
{
suma+=a%10;
a/=10;
}
int sumb=0;
while(b)
{
sumb+=b%10;
b/=10;
}
return max(suma,sumb);
}
int result(int a,int b,char op)
{
switch(op)
{
case '+' :
return a+b;
case '-' :
return b-a;
case '*' :
return a*b;
case '/' :
return b/a;
case 'S' :
return Smax(a,b);
}
}
int jisuan()
{
stack<int>num;
int sum=0;
for(int i=0; post[i]; i++)
{
if(isNum(post[i]))
sum=sum*10+post[i]-'0';
else
{
if(sum!=0)
{
num.push(sum);
sum=0;
}
if(post[i]!=' ')
{
int a=num.top();
num.pop();
int b=num.top();
num.pop();
num.push(result(a,b,post[i]));
}
}
}
return num.top();
}
int main()
{
// freopen("2.txt","r",stdin);
///定义优先级,'S'表示的是Smax这个算法,优先级最大
pri['=']=0;
pri['(']=1;
pri['+']=2;
pri['-']=2;
pri['*']=3;
pri['/']=3;
pri['S']=4;
int t;
scanf("%d",&t);
while(t--)
{
memset(in,0,sizeof(in));
memset(post,0,sizeof(post));
scanf(" %s",in);
zhuan();
//puts(post);
printf("%d\n",jisuan());
}
return 0;
}
NYOJ 1272 表达式求值 第九届省赛 (字符串处理)的更多相关文章
-
NYOJ 35 表达式求值(逆波兰式求值)
http://acm.nyist.net/JudgeOnline/problemset.php?typeid=4 NYOJ 35 表达式求值(逆波兰式求值) 逆波兰式式也称后缀表达式. 一般的表达式求 ...
-
nyoj 305 表达式求值 (递归)
表达式求值 时间限制:3000 ms | 内存限制:65535 KB 难度:3 描述 Dr.Kong设计的机器人卡多掌握了加减法运算以后,最近又学会了一些简单的函数求值,比如,它知道函数min ...
-
NYOJ 305 表达式求值 (字符串处理)
题目链接 描述 Dr.Kong设计的机器人卡多掌握了加减法运算以后,最近又学会了一些简单的函数求值,比如,它知道函数min(20,23)的值是20 ,add(10,98) 的值是108等等.经过训练, ...
-
NYOJ 35 表达式求值 (字符串处理)
题目链接 描述 ACM队的mdd想做一个计算器,但是,他要做的不仅仅是一计算一个A+B的计算器,他想实现随便输入一个表达式都能求出它的值的计算器,现在请你帮助他来实现这个计算器吧. 比如输入:&quo ...
-
nyoj(表达式求值)
描述 ACM队的mdd想做一个计算器,但是,他要做的不仅仅是一计算一个A+B的计算器,他想实现随便输入一个表达式都能求出它的值的计算器,现在请你帮助他来实现这个计算器吧. 比如输入:"1+2 ...
-
NYOJ 35 表达式求值
一个模板了 哈哈. 这题由于已经包括了整形.浮点形了,以后也不须要特别处理了. /* 这里主要是逆波兰式的实现,使用两个stack 这里用字符串来模拟一个stack,第一步,将中缀表达式转变为后缀表达 ...
-
NYOJ - 35 表达式求值 分类: NYOJ 2015-03-18 10:33 31人阅读 评论(0) 收藏
#include<iostream> #include<string> #include<stack> #include<cstdio> using n ...
-
河南省acm第九届省赛--《表达式求值》--栈和后缀表达式的变形--手速题
表达式求值 时间限制:1000 ms | 内存限制:65535 KB 难度:3 描述 假设表达式定义为:1. 一个十进制的正整数 X 是一个表达式.2. 如果 X 和 Y 是 表达式,则 X+Y, ...
-
数据结构--栈的应用(表达式求值 nyoj 35)
题目链接:http://acm.nyist.net/JudgeOnline/problem.php?pid=35 题目: 表达式求值 时间限制:3000 ms | 内存限制:65535 KB描述 AC ...
随机推荐
-
redis并发问题
redis中的并发问题 使用redis作为缓存已经很久了,redis是以单进程的形式运行的,命令是一个接着一个执行的,一直以为不会存在并发的问题,直到今天看到相关的资料,才恍然大悟~~ 具体问题实例 ...
-
reactjs
摘自阮一峰博客:http://www.ruanyifeng.com/blog/2015/03/react.html 现在最热门的前端框架,毫无疑问是 React . 上周,基于 React 的 Rea ...
-
《day16_多线程细节_Eclipse使用》
多线程的一些细节: 1,面试题:sleep方法和wait方法异同点是什么? 相同点:可以让线程处于冻结状态. 不同点: 1, sleep必须指定时间. wait可以指定时间,也可以不指定时间. 2, ...
-
VBS基础篇 - RegExp 对象
正则表达式(RegExp)对象下面的代码说明了RegExp对象的用法: Function RegExpTest(patrn, strng) Dim regEx, Match, Matches '创建变 ...
-
How-to Dump Keys from Memcache--reference
Submitted by Lars Windolf on 19. October 2012 - 21:53 http://lzone.de/dump%20memcache%20keys You spe ...
-
HDU P4578 Transformation
Problem Description Yuanfang is puzzled with the question below: There are n integers, a1, a2, …, an ...
-
python使用VBA:Excel创建图表(转)
# -*- coding: utf-8 -*- """ Created on Thu Mar 06 11:22:03 2014 @author: Administrato ...
-
injector
angular 提供了一套依赖注入的机制,和后台很像.虽然我不觉得有很重要. var $injector = angular.injector(["myModule"]); var ...
-
ubuntu root 密码是随机的! root权限下设置共享文件夹
一.Ubuntu的默认root密码是随机的,即每次开机都有一个新的root密码.我们可以在终端输入命令 sudo passwd,然后输入当前用户的密码,enter, 二.终端会提示我们输入新的密码并确 ...
-
Oracle之SQL优化专题02-稳固SQL执行计划的方法
首先构建一个简单的测试用例来实际演示: create table emp as select * from scott.emp; create table dept as select * from ...