题目描述
对于1位二进制变量定义两种运算:
运算的优先级是:
1.先计算括号内的,再计算括号外的。
2.“×”运算优先于“⊕”运算,即计算表达式时,先计算×运算,再计算⊕运算。
例如:计算表达式A⊕B×C时,先计算B×C,其结果再与A做⊕运算。
现给定一个未完成的表达式,例如_+(_×_),请你在横线处填入数字0或者1,请问有多少种填法可以使得表达式的值为0。
输入格式
共2行:
第一行为一个整数 L,表示给定的表达式中除去横线外的运算符和括号的个数。
第二行为一个字符串包含L个字符,其中只包含“(”、“)”、“+”、“×”这4种字符,其中“(”、“)”是左右括号,“+”、“×”分别表示前面定义的运算符“⊕”和“×”。这行字符按顺序给出了给定表达式中除去变量外的运算符和括号。
输出格式
一行,包含一个整数,即所有的方案数。注意:这个数可能会很大,请输出方案数对10007取模后的结果。
输入样例
4
+(*)
输出样例
3
数据规模
对于20%的数据,0≤L≤10。
对于50%的数据,0≤L≤1000。
对于70%的数据,0≤L≤10000。
对于100%的数据,0≤L≤100000。
对于50%的数据输入表达式中不含括号。
题解
题目中给出的是中缀表达式,我们可以先用单调栈转后缀表达式(不会的可以百度),然后补上数字的位,在模拟运算一遍这个表达式即可。
![](https://i-blog.csdnimg.cn/blog_migrate/8f900a89c6347c561fdf2122f13be562.gif)