P1054 等价表达式

题目描述

明明进了中学之后,学到了代数表达式。有一天,他碰到一个很麻烦的选择题。这个题目的题干中首先给出了一个代数表达式,然后列出了若干选项,每个选项也是一个代数表达式,题目的要求是判断选项中哪些代数表达式是和题干中的表达式等价的。

这个题目手算很麻烦,因为明明对计算机编程很感兴趣,所以他想是不是可以用计算机来解决这个问题。假设你是明明,能完成这个任务吗?

这个选择题中的每个表达式都满足下面的性质:

1. 表达式只可能包含一个变量‘a’。

2. 表达式中出现的数都是正整数,而且都小于10000。

3. 表达式中可以包括四种运算‘+’(加),‘-’(减),‘*’(乘),‘^’(乘幂),以及小括号‘(’,‘)’。小括号的优先级最高,其次是‘^’,然后是‘*’,最后是‘+’和‘-’。‘+’和‘-’的优先级是相同的。相同优先级的运算从左到右进行。(注意:运算符‘+’,‘-’,‘*’,‘^’以及小括号‘(’,‘)’都是英文字符)

4. 幂指数只可能是1到10之间的正整数(包括1和10)。

5. 表达式内部,头部或者尾部都可能有一些多余的空格。

下面是一些合理的表达式的例子:

((a^1) ^ 2)^3,a*a+a-a,((a+a)),9999+(a-a)*a,1 + (a -1)^3,1^10^9……

输入输出格式

输入格式:

输入文件equal.in的第一行给出的是题干中的表达式。第二行是一个整数n(2 <= n <= 26),表示选项的个数。后面n行,每行包括一个选项中的表达式。这n个选项的标号分别是A,B,C,D……

输入中的表达式的长度都不超过50个字符,而且保证选项中总有表达式和题干中的表达式是等价的。

输出格式:

输出文件equal.out包括一行,这一行包括一系列选项的标号,表示哪些选项是和题干中的表达式等价的。选项的标号按照字母顺序排列,而且之间没有空格。

输入输出样例

输入样例#1:

( a + 1) ^2
3
(a-1)^2+4*a
a + 1+ a
a^2 + 2 * a * 1 + 1^2 + 10 -10 +a -a
输出样例#1:

AC

说明

对于30%的数据,表达式中只可能出现两种运算符‘+’和‘-’;

对于其它的数据,四种运算符‘+’,‘-’,‘*’,‘^’在表达式中都可能出现。

对于全部的数据,表达式中都可能出现小括号‘(’和‘)’。

2005年提高组第四题

/*
给a 随机几个值,都可以的话等价的概率大一些
注意随时取模,别乘爆了。
其他就是栈模拟中缀表达式,挺恶心的。
读入都有坑,还要判断括号是否匹配。
*/
#include<iostream>
#include<cstdio>
#include<cstring>
#include<stack> #define ll long long
#define mod 1000007 using namespace std; ll pri[];
stack <ll> num,ope;
string map[],str;
ll n,ans[],len,i,j,k;
char c; inline void read()
{
c=getchar();
while(c=='\n' || c=='\r') c=getchar();
while(c!='\n' && c!='\r'){if(c!=' ') map[]+=c;c=getchar();}
scanf("%lld",&n);
for(i=;i<=n;i++)
{
while(c=='\n' || c=='\r') c=getchar();
while(c!='\n' && c!='\r'){if(c!=' ')map[i]+=c;c=getchar();}
}
} inline ll ksm(ll x,ll y)
{
if(y==) return x;
ll k=ksm(x,y/);
if(y & ) return (k*k*x)%mod;
return (k*k)%mod;
} void solve()
{
for(k=;k<=;k++)
{
while(!num.empty()) num.pop();
while(!ope.empty()) ope.pop();
for(i=;i<=len;i++)
{
if(str[i]=='a') num.push(k);
else if(str[i]>='' && str[i]<='')
{
ll tmp=;
while(str[i]>='' && str[i]<='')
tmp=tmp*+str[i]-'',i++;
num.push(tmp);
i--;
}
else if(str[i]==')')
{
bool flag=;
if(ope.empty()) break;
while(ope.top()!=(ll)'(')
{
c=ope.top();ope.pop();
ll num1=num.top();num.pop();
ll num2=num.top();num.pop();
if(c=='*') num.push((num2*num1)%mod);
if(c=='+') num.push((num2+num1)%mod);
if(c=='-') num.push((num2-num1)%mod);
if(c=='^') num.push(ksm(num2,num1));
if(ope.empty()) break;
}
if(ope.empty()) break;
ope.pop();
}
else if(ope.empty()) ope.push(str[i]);
else if(str[i]=='(') ope.push(str[i]);
else
{
c=ope.top();
if(c=='(')
{
ope.push(str[i]);
continue;
}
while()
{
if(ope.empty()) break;
c=ope.top();
if(pri[c]<pri[str[i]] || c=='(') break;
ope.pop();
ll num1=num.top();num.pop();
ll num2=num.top();num.pop();
if(c=='*') num.push((num2*num1)%mod);
if(c=='+') num.push((num2+num1)%mod);
if(c=='-') num.push((num2-num1)%mod);
if(c=='^') num.push(ksm(num2,num1));
}
ope.push(str[i]);
}
}
while(!ope.empty())
{
while()
{
if(ope.empty()) break;
c=ope.top();
if(c!=')') break;
ope.pop();
if(c==')' && ope.top()=='(') ope.pop();
else break;
}
if(ope.empty() || num.size()==) break;
ll num1=num.top();num.pop();
ll num2=num.top();num.pop();
c=ope.top();ope.pop();
if(c=='*') num.push((num2*num1)%mod);
if(c=='+') num.push((num2+num1)%mod);
if(c=='-') num.push((num2-num1)%mod);
if(c=='^') num.push( ksm(num2,num1));
}
int otk=num.top();
while(otk<) otk+=mod;
if(j && ans[k]!=otk) break;
if(j==)
{
ans[k]=num.top();
while(ans[k]<) ans[k]+=mod;
}
}
} int main()
{
pri['(']=pri[')']=;pri['^']=;
pri['*']=;pri['+']=pri['-']=;
read();
for(j=;j<=n;j++)
{
str=map[j];
len=str.size()-;
solve();
if(j && k==) printf("%c",j+'A'-);
}
printf("\n");
return ;
}

等价表达式 2005年NOIP全国联赛提高组(栈模拟)的更多相关文章

  1. 过河 2005年NOIP全国联赛提高组(离散化+dp)

    1105 过河 2005年NOIP全国联赛提高组  时间限制: 1 s  空间限制: 128000 KB  题目等级 : 钻石 Diamond       题目描述 Description 在河上有一 ...

  2. Codevs 1105 过河 2005年NOIP全国联赛提高组

    1105 过河 2005年NOIP全国联赛提高组 时间限制: 1 s 空间限制: 128000 KB 题目等级 : 钻石 Diamond 题目描述 Description 在河上有一座独木桥,一只青蛙 ...

  3. Vigenère密码 2012年NOIP全国联赛提高组(字符串模拟)

    P1079 Vigenère 密码 题目描述 16 世纪法国外交家 Blaise de Vigenère 设计了一种多表密码加密算法――Vigenère 密 码.Vigenère 密码的加密解密算法简 ...

  4. Codevs 1200 同余方程 2012年NOIP全国联赛提高组

    1200 同余方程 2012年NOIP全国联赛提高组 时间限制: 1 s 空间限制: 128000 KB 题目等级 : 钻石 Diamond 题目描述 Description 求关于 x 同余方程 a ...

  5. Codevs 1069 关押罪犯 2010年NOIP全国联赛提高组

    1069 关押罪犯 2010年NOIP全国联赛提高组 时间限制: 1 s 空间限制: 128000 KB 题目等级 : 钻石 Diamond 题目描述 Description S 城现有两座监狱,一共 ...

  6. Codevs 1218 疫情控制 2012年NOIP全国联赛提高组

    1218 疫情控制 2012年NOIP全国联赛提高组 时间限制: 2 s 空间限制: 128000 KB 题目等级 : 钻石 Diamond 题目描述 Description H 国有 n 个城市,这 ...

  7. Codevs 3289 花匠 2013年NOIP全国联赛提高组

    3289 花匠 2013年NOIP全国联赛提高组 时间限制: 1 s 空间限制: 128000 KB 题目等级 : 钻石 Diamond 题目描述 Description 花匠栋栋种了一排花,每株花都 ...

  8. Codevs 1173 最优贸易 2009年NOIP全国联赛提高组

    1173 最优贸易 2009年NOIP全国联赛提高组 时间限制: 1 s 空间限制: 128000 KB 题目等级 : 钻石 Diamond 题目描述 Description [问题描述] C 国有n ...

  9. Codevs 3731 寻找道路 2014年 NOIP全国联赛提高组

    3731 寻找道路 时间限制: 1 s 空间限制: 128000 KB 题目等级 : 黄金 Gold 题目描述 Description 在有向图G中,每条边的长度均为1,现给定起点和终点,请你在图中找 ...

随机推荐

  1. Haoop Mapreduce 中的FileOutputFormat类

    FileOutputFormat类继承OutputFormat,需要提供所有基于文件的OutputFormat实现的公共功能,主要有以下两点: (1)实现checkOutputSpecs方法 chec ...

  2. keepalived(nginx的高可用)安装文档

    1. 安装环境 su - root yum -y install kernel-devel* yum -y install openssl-* yum -y install popt-devel yu ...

  3. 通过response对象的sendRedirect方法重定向网页

    通过response对象的sendRedirect方法重定向网页 制作人:全心全意 使用response对象提供的sendRedirect()方法可以将网页重定向到另一个页面.重定向操作支持将地址重定 ...

  4. Swoft 新手向教程 - 通过 Docker 搭建一个开发环境

    本系列文章将从使用层面介绍 Swoft 框架的使用及业务开发,面向初中级的 PHPer Swoft首个基于 Swoole 原生协程的新时代 PHP 高性能协程全栈组件化框架,内置协程网络服务器及常用的 ...

  5. Laravel学习:请求到响应的生命周期

    Laravel请求到响应的整个执行过程,主要可以归纳为四个阶段,即程序启动准备阶段.请求实例化阶段.请求处理阶段.响应发送和程序终止阶段. 程序启动准备阶段 服务容器实例化 服务容器的实例化和基本注册 ...

  6. LA 3029 City Game

    LA 3029 求最大子矩阵问题,主要考虑枚举方法,直接枚举肯定是不行的,因为一个大矩阵的子矩阵个数是指数级的,因此应该考虑先进行枚举前的扫描工作. 使用left,right,up数组分别记录从i,j ...

  7. Shiro_权限 URL 配置细节

    [部分细节] 1.[urls] 部分的配置,其格式是:“url=拦截器[参数],拦截器[参数]”: 2.如果当前请求的URL匹配 [urls] 部分的某个url模式,将会执行其配置的拦截器. 3.an ...

  8. Linux上安装Hadoop集群(CentOS7+hadoop-2.8.0)--------hadoop环境的搭建

    Linux上安装Hadoop集群(CentOS7+hadoop-2.8.0)------https://blog.csdn.net/pucao_cug/article/details/71698903 ...

  9. NYOJ 832 合并游戏

    合并游戏 时间限制:1000 ms  |  内存限制:65535 KB 难度:4   描述 大家都知道Yougth除了热爱编程之外,他还有一个爱好就是喜欢玩.某天在河边玩耍的时候,他发现了一种神奇的石 ...

  10. [luoguP1026] 统计单词个数(DP)

    传送门 题解 #include <cstdio> #include <cstring> #define max(x, y) ((x) > (y) ? (x) : (y)) ...