P8997 [CEOI 2022] Homework
题目描述
这是 Helena 的数学作业中的一道题:
我们定义合法表达式如下:
- `?` 是合法表达式,这表示一个未知数。
- 如果 $A,B$ 均为合法表达式,那么 $\texttt{min(}A\texttt{,}B\texttt{)}$ 和 $\texttt{max(}A\texttt{,}B\texttt{)}$ 均为合法表达式,这分别表示取左右两边的最大值/最小值。
设 `?` 的个数为 $N$,现在给出一个合法表达式,将每一个问号替换为 $1\sim N$ 中的任意一个数并且每一个数不能使用多次,可以得到多少种不同的答案?
可怜的 Helena 并不会做,请你帮帮她。
输入格式
仅一行一个字符串表示给出的合法表达式。
输出格式
输出一个整数,表示不同答案的个数。
说明/提示
### 样例 1 解释
无论权值如何选择,最后的答案都会是 $\min\{1,2,3,4\}$,也就是 $1$。
### 样例 2 解释
答案为 $4$ 的方案是: `4=max(4,max(3,min(2,1)))`,答案为 $3$ 的方案是 `3=max(3,max(2,min(1,4)))`,可以证明答案不可能为 $1$ 或 $2$。
### 数据规模与约定
对于全部数据,$2\le N\le 10^6$。
| Subtask 编号 | 特殊限制 | 得分 |
| :----------: | :--------------------------------------------------------------------------: | :--: |
| $1$ | $N\le 9$ | $10$ |
| $2$ | $N\le 16$ | $13$ |
| $3$ | 对于任意 $\texttt{min(}A\texttt{,}B\texttt{)}$ 与 $\texttt{max(}A\texttt{,}B\texttt{)}$,$A$ 和 $B$ 中有一个为 `?`。 | $13$ |
| $4$ | $N\le 10^3$ | $30$ |
| $5$ | 无特殊限制 | $34$ |