vijos-1003等价表达式
明明进了中学之后,学到了代数表达式。有一天,他碰到一个很麻烦的选择题。这个题目的题干中首先给出了一个代数表达式,然后列出了若干选项,每个选项也是一个代数表达式,题目的要求是判断选项中哪些代数表达式是和题干中的表达式等价的。这个题目手算很麻烦,因为明明对计算机编程很感兴趣,所以他想是不是可以用计算机来解决这个问题。假设你是明明,能完成这个任务吗?这个选择题中的每个表达式都满足下面的性质: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……对于30%的数据,表达式中只可能出现两种运算符‘+’和‘-’;对于其它的数据,四种运算符‘+’,‘-’,‘*’,‘^’在表达式中都可能出现。对于全部的数据,表达式中都可能出现小括号‘(’和‘)’。分析:
1.不需要考虑括号不匹配问题,输入绝对合法。
2.不需要考虑形如
(-3+a^7)*2
这样的情况。
3.另一方面,我认为只有试够11个数才能充分说明正确性:因为
a^10+k9a^9+k8a^8+.......=(a+3)^10+......
这是一个一元十次方程,它需要11个点来确定一条十次曲线。所以要将0-10都代入才能说明问题。
当然,如果这是一条6次曲线,7个点就够,可是谁有想写一个判断次数的函数呢?
4.因为取余运算,导致运算顺序不同,结果就不同。这是一个神坑。所以试的点少一点 ,取余数大一点就容易过。
#include<iostream> using namespace std; #define big 10007 #define test 8 char ti[51];//题干 int size;//选项个数 int result[test];//准备试的数 bool prior(char a, char b){//运算符a优先级是否大于b if (a == '^')return true; if (b == '^')return false; if (a == '*')return true; if (b == '*')return false; return true; } int power(int a, int b){//乘幂函数要取余 int i; int ans = 1; for (i = 0; i < b; i++){ ans *= a; ans %= big; } return ans; } int op(int a, int b, char o){ switch (o){ case '^':return power(a, b); case '*':a *= b; a %= big; return a; case '+':return (a + b) % big; case '-':return (a - b) % big; } } //x表示数字,o表示符号 int calculate(int x[], int xsize, char o[], int osize){ int i; int xstack[51]; int xtop = 0; char ostack[51]; int otop = 0; int xi, oi; xi = oi = 0; xstack[xtop++] = x[xi++]; while (xi<xsize&&oi<osize){ while (otop != 0 && prior(ostack[otop - 1], o[oi])){ xstack[xtop - 2] = op(xstack[xtop - 2], xstack[xtop - 1], ostack[otop - 1]); xtop--; otop--; } ostack[otop++] = o[oi++]; xstack[xtop++] = x[xi++]; } while (otop >0){ xstack[xtop - 2] = op(xstack[xtop - 2], xstack[xtop - 1], ostack[otop - 1]); xtop--; otop--; } return xstack[0]; } int go(char ex[], int a){ int i, j; int x[51]; int xi = 0; char o[51]; int oi = 0; i = 0; while (ex[i]){ while (ex[i] == ' ')i++; if (ex[i] == 0)break; if (ex[i] == '('){ int left = 1; char temp[51]; j = 0; i++; while (true){ temp[j] = ex[i]; if (temp[j] == '(')left++; else if (temp[j] == ')')left--; if (left == 0){ temp[j] = 0; x[xi++] = go(temp, a); i++; break; } i++; j++; } } else if (ex[i] == 'a'){ x[xi++] = a; i++; } else{ int n = 0; while (ex[i] >= '0'&&ex[i] <= '9'){ n *= 10; n += ex[i] - '0'; i++; } x[xi++] = n; } while (ex[i] == ' ')i++; if (ex[i] == 0)break; if (ex[i] == '+' || ex[i] == '-' || ex[i] == '*' || ex[i] == '^'){ o[oi++] = ex[i]; } i++; } return calculate(x, xi, o, oi); } int main(){ freopen("in.txt", "r", stdin); cin.getline(ti, sizeof(ti)); cin >> size; int i; for (i = 0; i < test; i++) { result[i] = go(ti, i); } char choose[51]; cin.getline(choose, 55); for (i = 0; i < size; i++){ cin.getline(choose, 55); int j; int ans; for (j = 0; j < test; j++){ ans = go(choose, j); if (ans != result[j])break; } if (j == test){ cout << (char)(i + 'A'); } } return 0; }
vijos-1003等价表达式的更多相关文章
- Vijos P1003 等价表达式 随机数+单调栈
题目链接:https://vijos.org/p/1003 题意: 1. 表达式只可能包含一个变量‘a’. 2. 表达式中出现的数都是正整数,而且都小于10000. 3. 表达式中可以包括四种运算‘+ ...
- 数据结构--栈 codevs 1107 等价表达式
codevs 1107 等价表达式 2005年NOIP全国联赛提高组 时间限制: 1 s 空间限制: 128000 KB 题目等级 : 钻石 Diamond 题目描述 Descripti ...
- 等价表达式(noip2005)
3.等价表达式 [问题描述] 兵兵班的同学都喜欢数学这一科目,中秋聚会这天,数学课代表给大家出了个有关代数表达式的选择题.这个题目的题干中首先给出了一个代数表达式,然后列出了若干选项,每个选项也 ...
- 洛谷 P1054 等价表达式 解题报告
P1054 等价表达式 题目描述 明明进了中学之后,学到了代数表达式.有一天,他碰到一个很麻烦的选择题.这个题目的题干中首先给出了一个代数表达式,然后列出了若干选项,每个选项也是一个代数表达式,题目的 ...
- 洛谷P1054 等价表达式
P1054 等价表达式 题目描述 明明进了中学之后,学到了代数表达式.有一天,他碰到一个很麻烦的选择题.这个题目的题干中首先给出了一个代数表达式,然后列出了若干选项,每个选项也是一个代数表达式,题目的 ...
- 等价表达式 2005年NOIP全国联赛提高组(栈模拟)
P1054 等价表达式 题目描述 明明进了中学之后,学到了代数表达式.有一天,他碰到一个很麻烦的选择题.这个题目的题干中首先给出了一个代数表达式,然后列出了若干选项,每个选项也是一个代数表达式,题目的 ...
- 洛谷 P1054 等价表达式
洛谷 P1054 等价表达式 题目描述 明明进了中学之后,学到了代数表达式.有一天,他碰到一个很麻烦的选择题.这个题目的题干中首先给出了一个代数表达式,然后列出了若干选项,每个选项也是一个代数表达式, ...
- 表达式求值(noip2015等价表达式)
题目大意 给一个含字母a的表达式,求n个选项中表达式跟一开始那个等价的有哪些 做法 模拟一个多项式显然难以实现那么我们高兴的找一些素数代入表达式,再随便找一个素数做模表达式求值优先级表 - ( ) + ...
- NOIP2005 等价表达式
题目描述 明明进了中学之后,学到了代数表达式.有一天,他碰到一个很麻烦的选择题.这个题目的题干中首先给出了一个代数表达式,然后列出了若干选项,每个选项也是一个代数表达式,题目的要求是判断选项中哪些代数 ...
随机推荐
- Oracle Dataguard的原理与基本配置
最近集团在做灾备方案,用于Oracle的高可用性,在不影响主库性能的前提下,我们选择使用DG的"最大性能"模式. DG是Oracle数据库自带的数据同步功能,其基本原理是将日志 ...
- Wish You to Remember
Just to myself: it is not complicate. And I don't know its internal principle now. (ms08-067) But I ...
- 蜕变·WebRebuild 2013 前端年度交流会邀请
联网web前端设计行业通过一段时期的茧封或焰炼,web技术使行业.企业及自身发生质的改变.痛苦的蜕变是成长的契机,在彼此互相冲击.交流.融合的对话下,将以尊重包容互助合作同步发展的心态,对行业蜕变.自 ...
- Stanford coursera Andrew Ng 机器学习课程编程作业(Exercise 1)
Exercise 1:Linear Regression---实现一个线性回归 在本次练习中,需要实现一个单变量的线性回归.假设有一组历史数据<城市人口,开店利润>,现需要预测在哪个城市中 ...
- leetcode-HouseRobber
这道题比较简单,所以我会介绍的比较粗略: 题目: 有一个小偷想沿着马路上的房子偷东西,每家每户都有一些钱,但这条街上装了监控系统,如果相邻的两户人家都被偷了的话那么就会触发报警器.小偷的目标就是在不触 ...
- Unity Shaders and Effets Cookbook
Unity Shaders and Effects Cookbook 最近在读 <Unity Shaders and Effects Cookbook> 中文名称:<Unity 着色 ...
- UBUNTU添加新的分辨率
首先,直接运行xrandr查看下分辨率的情况: $ xrandr Screen 0: minimum 320 x 200, current 1280 x 1024, maximum 4096 x 40 ...
- [No000036]操作系统Operating Systems系统调用的实现System_Call
实现一个whoami 系统调用 系统调用的直观实现 问题+直观想法… 用户程序调用whoami, 一个字符串"systemcall "放在操作系统中(系统引导时载入) ,取出来打印 ...
- 转载 Appstore 上传被拒原因及解释
原 apps被拒绝的各种理由以及翻译 1. Terms and conditions(法律与条款) 2. Functionality(功能) 3. Metadata (name, descriptio ...
- Memcached和Memcache安装(64位win7)
一.Memcached和Memcache的区别: 网上关于Memcached和Memcache的区别的理解众说纷纭,我个人的理解是: Memcached是一个内存缓存系统,而Memcache是php的 ...