UOI 的题面是一个外星八爪鱼用脚写的。
由于题面写的很差,大D米不得不不断提问来确认题意。但外星八爪鱼没有手回复,只好叫你来帮忙。
这些问题可以抽象成一个栈的结构,初始为空,大D米有两种操作:
push
:新提一个问题置于栈顶。此时你需要对问题做出以下两种回应之一:R(no Response)或 B(Buzhidao)。pop
:大D米在胡乱提交后知道了栈顶问题的答案,问题从栈中移除。
这些操作按时间顺序形成了一个长为
你需要保证任意时刻栈中 R 类回应数量不超过
两种回应都很敷衍,B 类回应更让人愤怒。如果你的整个回应过程中,做出了
现在,你想知道所有回应方案中大D米愤怒值的总和。答案可能很大,你只需要输出其对
输入格式
第一行三个整数
接下来 push
或 pop
的字符串,描述操作序列。
输出格式
输出一行一个整数,表示所有回应方案中大D米愤怒值的总和对
样例一
input
3 1 2 push push push pop pop pop
output
12
explanation
由于操作过程是先放入三个问题再依次移除,所以要求三个回复中恰好有
样例二
input
3 1 2 push push pop push pop pop
output
14
explanation
若第一个问题回的是 R,则剩余两个问题都只能选择回 B,总共有
若第一个问题回的是 B,则剩余两个问题没有限制。
- 若这两次都回 B,则有
种方案,权值为 ; - 若这两次都回 R,则有
种方案,权值为 ; - 若这两次回应不同,则有
种方案,权值为 。
所以所有方案的愤怒值和为
样例三
见附加文件中 ex_stack3.in
与 ex_stack3.out
,该组样例满足子任务 1 的性质。
样例四
见附加文件中 ex_stack4.in
与 ex_stack4.out
,该组样例满足子任务 3 的性质。
样例五
见附加文件中 ex_stack5.in
与 ex_stack5.out
,该组样例满足子任务 5 的性质。
限制与约定
对于
子任务编号 | 特殊性质 | 分值 | |
---|---|---|---|
无 | |||
无 |
时间限制:
空间限制: