P1054 等价表达式
题目描述
明明进了中学之后,学到了代数表达式。有一天,他碰到一个很麻烦的选择题。这个题目的题干中首先给出了一个代数表达式,然后列出了若干选项,每个选项也是一个代数表达式,题目的要求是判断选项中哪些代数表达式是和题干中的表达式等价的。
这个题目手算很麻烦,因为明明对计算机编程很感兴趣,所以他想是不是可以用计算机来解决这个问题。假设你是明明,能完成这个任务吗?
这个选择题中的每个表达式都满足下面的性质:
- 表达式只可能包含一个变量‘aa’。
- 表达式中出现的数都是正整数,而且都小于1000010000。
- 表达式中可以包括四种运算
+
(加),-
(减),*
(乘),^
(乘幂),以及小括号(
,)
。小括号的优先级最高,其次是^
,然后是*
,最后是+
和-
。+
和-
的优先级是相同的。相同优先级的运算从左到右进行。(注意:运算符+
,-
,*
,^
以及小括号(
,)
都是英文字符) - 幂指数只可能是11到1010之间的正整数(包括11和1010)。
- 表达式内部,头部或者尾部都可能有一些多余的空格。
下面是一些合理的表达式的例子:
((a^1) ^ 2)^3
,a*a+a-a
,((a+a))
,9999+(a-a)*a
,1 + (a -1)^3
,1^10^9
………
输入输出格式
输入格式:
第一行给出的是题干中的表达式。
第二行是一个整数n(2 \le n \le 26)n(2≤n≤26),表示选项的个数。后面nn行,每行包括一个选项中的表达式。这nn个选项的标号分别是A,B,C,D…A,B,C,D…
输入中的表达式的长度都不超过50个字符,而且保证选项中总有表达式和题干中的表达式是等价的。
输出格式:
一行,包括一系列选项的标号,表示哪些选项是和题干中的表达式等价的。选项的标号按照字母顺序排列,而且之间没有空格。
输入输出样例
( a + 1) ^2
3
(a-1)^2+4*a
a + 1+ a
a^2 + 2 * a * 1 + 1^2 + 10 -10 +a -a
AC
说明
对于30%的数据,表达式中只可能出现两种运算符‘+’和-
;
对于其它的数据,四种运算符+
,-
,*
,^
在表达式中都可能出现。
对于全部的数据,表达式中都可能出现小括号(
和)
。
2005年提高组第四题
Solution:
Noip的题目,满满的恶意((・◇・)?读入有毒啊!)。
读入一行字符串,本题不能用gets或者cin.getline(因为我试了),所以得手写读入(判断换行'\n'和回车'\r')。
思路就是随便代10个数计算每个表达式的值,然后判断是否都相等就好了。
求的话可以用双栈模拟(一个存数,一个单调维护符号优先级),或者递归求,递归过程直接区间从后往前,用hash的思路统计算术优先级(优先级:'('>'^'>'*'>'+'='-'>')'),优先运算优先级高的就好了。
代码:
/*Code by 520 -- 8.31*/
#include<bits/stdc++.h>
#define il inline
#define ll long long
#define RE register
#define For(i,a,b) for(RE int (i)=(a);(i)<=(b);(i)++)
#define Bor(i,a,b) for(RE int (i)=(b);(i)>=(a);(i)--)
using namespace std;
const int N=,mod=1e9+;
int n,len[N],sum[N];
char s[][N],t[N]; il ll fast(ll x,ll k){
ll ans=;
while(k){
if(k&) ans=ans*x%mod;
k>>=;
x=x*x%mod;
}
return ans;
} int p[N];
ll dfs(char *s,int l,int r,int x){
int tot=,minn=0x7fffffff,pos=l,cnt=,num=;
memset(p,0x3f,sizeof(p));
Bor(i,l,r){
if(s[i]==')') tot+=;
if(s[i]=='(') tot-=;
if(s[i]=='^') p[i]=tot+,cnt++;
if(s[i]=='*') p[i]=tot+,cnt++;
if(s[i]=='+'||s[i]=='-') p[i]=tot+,cnt++;
if(minn>p[i]) minn=p[i],pos=i;
}
if(!cnt){
For(i,l,r) if(s[i]=='a')return x;
For(i,l,r) if(isdigit(s[i])) num=(num<<)+(num<<)+(s[i]^);
return num;
}
if(s[pos]=='^') return fast(dfs(s,l,pos-,x),dfs(s,pos+,r,x));
if(s[pos]=='*') return dfs(s,l,pos-,x)*dfs(s,pos+,r,x)%mod;
if(s[pos]=='+') return (dfs(s,l,pos-,x)+dfs(s,pos+,r,x))%mod;
if(s[pos]=='-') return (dfs(s,l,pos-,x)-dfs(s,pos+,r,x))%mod;
return ;
} il void get(char *a){
char c=getchar();
int cnt=;
while(c=='\n'||c=='\r') c=getchar();
while(c!='\n'&&c!='\r') a[cnt++]=c,c=getchar();
a[cnt]='\0';
} int main(){
get(t),len[]=strlen(t);
cin>>n;
For(i,,n) get(s[i]),len[i]=strlen(s[i]);
For(i,,) sum[i]=dfs(t,,len[]-,i-);
For(i,,n) {
bool f=;
For(j,,) if(sum[j]!=dfs(s[i],,len[i]-,j-)){f=;break;}
if(!f)printf("%c",'A'+i-);
}
return ;
}
P1054 等价表达式的更多相关文章
- 洛谷 P1054 等价表达式 解题报告
P1054 等价表达式 题目描述 明明进了中学之后,学到了代数表达式.有一天,他碰到一个很麻烦的选择题.这个题目的题干中首先给出了一个代数表达式,然后列出了若干选项,每个选项也是一个代数表达式,题目的 ...
- 洛谷P1054 等价表达式
P1054 等价表达式 题目描述 明明进了中学之后,学到了代数表达式.有一天,他碰到一个很麻烦的选择题.这个题目的题干中首先给出了一个代数表达式,然后列出了若干选项,每个选项也是一个代数表达式,题目的 ...
- 洛谷 P1054 等价表达式
洛谷 P1054 等价表达式 题目描述 明明进了中学之后,学到了代数表达式.有一天,他碰到一个很麻烦的选择题.这个题目的题干中首先给出了一个代数表达式,然后列出了若干选项,每个选项也是一个代数表达式, ...
- 【数据结构】P1054 等价表达式
[题目链接] https://www.luogu.org/problem/P1054 题目描述 明明进了中学之后,学到了代数表达式.有一天,他碰到一个很麻烦的选择题.这个题目的题干中首先给出了一个代数 ...
- [NOIP2005] 提高组 洛谷P1054 等价表达式
题目描述 明明进了中学之后,学到了代数表达式.有一天,他碰到一个很麻烦的选择题.这个题目的题干中首先给出了一个代数表达式,然后列出了若干选项,每个选项也是一个代数表达式,题目的要求是判断选项中哪些代数 ...
- 等价表达式 2005年NOIP全国联赛提高组(栈模拟)
P1054 等价表达式 题目描述 明明进了中学之后,学到了代数表达式.有一天,他碰到一个很麻烦的选择题.这个题目的题干中首先给出了一个代数表达式,然后列出了若干选项,每个选项也是一个代数表达式,题目的 ...
- 数据结构--栈 codevs 1107 等价表达式
codevs 1107 等价表达式 2005年NOIP全国联赛提高组 时间限制: 1 s 空间限制: 128000 KB 题目等级 : 钻石 Diamond 题目描述 Descripti ...
- 等价表达式(noip2005)
3.等价表达式 [问题描述] 兵兵班的同学都喜欢数学这一科目,中秋聚会这天,数学课代表给大家出了个有关代数表达式的选择题.这个题目的题干中首先给出了一个代数表达式,然后列出了若干选项,每个选项也 ...
- 表达式求值(noip2015等价表达式)
题目大意 给一个含字母a的表达式,求n个选项中表达式跟一开始那个等价的有哪些 做法 模拟一个多项式显然难以实现那么我们高兴的找一些素数代入表达式,再随便找一个素数做模表达式求值优先级表 - ( ) + ...
随机推荐
- javaweb(二十三)——jsp自定义标签开发入门
一.自定义标签的作用 自定义标签主要用于移除Jsp页面中的java代码. 二.自定义标签开发和使用 2.1.自定义标签开发步骤 1.编写一个实现Tag接口的Java类(标签处理器类) 1 packag ...
- Redis主从复制(Master/Slave) 与哨兵模式
Redis主从复制是什么? 行话:也就是我们所说的主从复制,主机数据更新后根据配置和策略, 自动同步到备机的master/slaver机制,Master以写为主,Slave以读为主 Redis主从复制 ...
- JavaScript 中函数的参数
functionName(parameter1, parameter2, parameter3) { // 要执行的代码…… } 参数规则 JavaScript 函数定义时形参没有指定数据类型. Ja ...
- vs2010(vs2012)好用的扩展插件介绍
一直以来只使用番茄vs助手(https://www.wholetomato.com/downloads/default.asp)辅助写代码,也都忘了是谁介绍的,不过确实好用. 相比原始的vs,它提供了 ...
- 《疯狂前端开发讲义jQuery+Angular+Bootstrap前端开发实践》学习笔记
<疯狂前端开发讲义jQuery+Angular+Bootstrap前端开发实践>学习笔记 二〇一九年二月十三日星期三2时28分54秒 前提:本书适合有初步HTML.CSS.JavaScri ...
- sqli-labs学习笔记 DAY1
DAY 1 准备工作 安装phpstudy 安装配置sqli-labs 学习笔记 SQL语句的注释:–, # +在URL经过编码后会编码为空格 SQL语句的查询语句:SELECT column_nam ...
- less 语法特性翻译稿 - 特性快速预览部分
原文地址 http://lesscss.cn/features/ 概述 作为CSS的一种扩展语法,Less不仅仅向后兼容CSS,新的特性也是基于CSS现有语法.这使得学习Less变得容易,如果你有所怀 ...
- We are writing to let you know we have removed your selling privileges
Hello, We are writing to let you know we have removed your selling privileges, canceled your listin ...
- Material Safety Data Sheet,MSDS - 化学品安全说明书
化学品安全说明书(Material Safety Data Sheet)MSDS,国际上称作化学品安全信息卡,是化学品生产商和经销商按法律要求必须提供的化学品理化特性(如PH值,闪点,易燃度,反应活性 ...
- “Hello World!“”团队第五周召开的第二次会议
今天是我们团队“Hello World!”团队第五周召开的第二次会议.也祝大家双十一快乐~~博客内容: 一.会议时间 二.会议地点 三.会议成员 四.会议内容 五.todo list 六.会议照片 七 ...