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 表达式求值 第九届省赛 (字符串处理)的更多相关文章

  1. NYOJ 35 表达式求值(逆波兰式求值)

    http://acm.nyist.net/JudgeOnline/problemset.php?typeid=4 NYOJ 35 表达式求值(逆波兰式求值) 逆波兰式式也称后缀表达式. 一般的表达式求 ...

  2. nyoj 305 表达式求值 (递归)

    表达式求值 时间限制:3000 ms  |  内存限制:65535 KB 难度:3   描述 Dr.Kong设计的机器人卡多掌握了加减法运算以后,最近又学会了一些简单的函数求值,比如,它知道函数min ...

  3. NYOJ 305 表达式求值 (字符串处理)

    题目链接 描述 Dr.Kong设计的机器人卡多掌握了加减法运算以后,最近又学会了一些简单的函数求值,比如,它知道函数min(20,23)的值是20 ,add(10,98) 的值是108等等.经过训练, ...

  4. NYOJ 35 表达式求值 (字符串处理)

    题目链接 描述 ACM队的mdd想做一个计算器,但是,他要做的不仅仅是一计算一个A+B的计算器,他想实现随便输入一个表达式都能求出它的值的计算器,现在请你帮助他来实现这个计算器吧. 比如输入:&quo ...

  5. nyoj(表达式求值)

    描述 ACM队的mdd想做一个计算器,但是,他要做的不仅仅是一计算一个A+B的计算器,他想实现随便输入一个表达式都能求出它的值的计算器,现在请你帮助他来实现这个计算器吧. 比如输入:"1+2 ...

  6. NYOJ 35 表达式求值

    一个模板了 哈哈. 这题由于已经包括了整形.浮点形了,以后也不须要特别处理了. /* 这里主要是逆波兰式的实现,使用两个stack 这里用字符串来模拟一个stack,第一步,将中缀表达式转变为后缀表达 ...

  7. NYOJ - 35 表达式求值 分类: NYOJ 2015-03-18 10:33 31人阅读 评论(0) 收藏

    #include<iostream> #include<string> #include<stack> #include<cstdio> using n ...

  8. 河南省acm第九届省赛--《表达式求值》--栈和后缀表达式的变形--手速题

    表达式求值 时间限制:1000 ms | 内存限制:65535 KB 难度:3   描述 假设表达式定义为:1. 一个十进制的正整数 X 是一个表达式.2. 如果 X 和 Y 是 表达式,则 X+Y, ...

  9. 数据结构--栈的应用(表达式求值 nyoj 35)

    题目链接:http://acm.nyist.net/JudgeOnline/problem.php?pid=35 题目: 表达式求值 时间限制:3000 ms | 内存限制:65535 KB描述 AC ...

随机推荐

  1. 结对编程学习fault、error、failure三种状态

    点滴成就 学习时间 新编写代码行数 博客量(篇) 学习知识点 第一周 10小时 0 0 了解软件工程 第二周 10小时 0 1 项目开题 第三周 15小时 0 1 开通博客.开展项目调查 第四周 20 ...

  2. MAVEN pom.xml 解读

    POM全称是Project Object  Model,即项目对象模型.pom.xml是maven的项目描述文件,它类似与antx的project.xml文件.pom.xml文件以xml的 形式描述项 ...

  3. Mac 常用快捷键整理

    Mac下常用的快捷键: Command+W 将当前窗口关闭(可以关闭Safari标签栏,很实用) Command+Option+M 将所有窗口最小化 Command+Q 关闭当前应用程序(相当于Doc ...

  4. php中ob缓存机制

    1.ob缓存运行方式 2.注意:在程序中如果开启ob_start(),所有的echo输出都会保存到ob缓存中,可以使用ob系列函数进行操作,如果没有,默认情况下,在程序执行结束,会把缓存中的数据发送给 ...

  5. Spring学习-1 框架总览

    Spring 是一个开源框架,是为了解决企业应用程序开发复杂性而创建的.框架的主要优势之一就是其分层架构,分层架构允许您选择使用哪一个组件,同时为 J2EE 应用程序开发提供集成的框架. spring ...

  6. v-for & duplicate key bug

    v-for & duplicate key bug vue warn & v-for & duplicate key bug <span class="audi ...

  7. 第76天:jQuery中的宽高

    Window对象和document对象的区别 1.window对象表示浏览器中打开的窗口 2.window对象可以省略,比如alert()也可以写成window.alert() Document对象是 ...

  8. 【bzoj4305】数列的GCD 组合数学+容斥原理

    题目描述 给出一个长度为N的数列{a[n]},1<=a[i]<=M(1<=i<=N).  现在问题是,对于1到M的每个整数d,有多少个不同的数列b[1], b[2], ..., ...

  9. 解析php addslashes()与addclashes()函数的区别和比较

    一. addslashes() 函数 addslashes(string) 函数在指定的预定义字符前添加反斜杠.这些预定义字符是:•单引号 (')•双引号 (")•反斜杠 (\)•NULL  ...

  10. Day22-CSRF跨站请求伪造

    csrf 跨站请求伪造 一.简介 django为用户实现防止跨站请求伪造的功能,通过中间件 django.middleware.csrf.CsrfViewMiddleware 来完成. 1.1 第1次 ...