CF2205E Simons and Dividing the Rhythm
题目描述
我紧握手中的烦恼,然后将它们抛向千里之外。
—— SHUN,《ONMYWAY》
假设 Simons 有一个长度为 $m$ 的数组 $a$。
Simons 需要对该数组执行如下操作,且仅能执行一次:
- 首先,他需要选择一个整数 $k$,并选定 $k$ 对整数 $[l_1, r_1], [l_2, r_2], \ldots, [l_k, r_k]$,使得:
- 对每个 $1\le i\le k$,都有 $l_i\le r_i$;
- $l_1=1$,$r_k=m$;
- 对每个 $i$($1 \leq i < k$),$r_i+1=l_{i+1}$。
- 然后,他分别将每个子数组 $[a_{l_i}, a_{l_i+1},\ldots, a_{r_i}]$ 独立地进行翻转。操作后,数组会变成 $[a_{r_1}, a_{r_1-1},\ldots, a_{l_1}, a_{r_2}, \ldots, a_{l_{k-1}}, a_{r_k}, a_{r_k-1}, \ldots, a_{l_k}]$。
现给定一个长度为 $n$ 的数组 $T$。请你统计有多少个数组 $S$,经过 Simons 执行如上的一次操作后,可以变换为 $T$。答案对 $998\,244\,353$ 取模。
输入格式
每组测试包含若干测试用例。第一行包含整数 $t$($1 \le t \le 8000$),表示测试用例的数量。
接下来每组测试包含:
第一行是一个整数 $n$($1 \le n \le 8000$),表示 $T$ 的长度。
第二行有 $n$ 个整数 $T_1, T_2, \ldots, T_n$($1\le T_i \le 8000$),表示数组 $T$ 的元素。
保证所有测试用例中 $n$ 的总和不超过 $8000$。
输出格式
对于每个测试用例,输出一个整数,表示满足条件的数组 $S$ 的数量,答案对 $998\,244\,353$ 取模。
说明/提示
对于第一个测试用例,只有如下几种数组能够被变换为 $T$:
- 对于 $S=[2,1,1,1]$,Simons 选择 $[1,3]$ 和 $[4,4]$,操作后数组变为 $[1,1,2,1]$,等于 $T$。
- 对于 $S=[1,2,1,1]$,Simons 选择 $[1,4]$。
- 对于 $S=[1,1,2,1]$,Simons 选择 $[1,2]$、$[3,3]$ 和 $[4,4]$。
- 对于 $S=[1,1,1,2]$,Simons 选择 $[1,2]$ 和 $[3,4]$。
对于第二个测试用例,只有如下几种数组能够被变换为 $T$:
- 对于 $S=[1,1,3,2]$,Simons 选择 $[1,1]$ 和 $[2,4]$。
- 对于 $S=[1,2,1,3]$,Simons 选择 $[1,1]$、$[2,2]$ 和 $[3,4]$。
- 对于 $S=[1,2,3,1]$,Simons 选择 $[1,1]$、$[2,2]$、$[3,3]$ 和 $[4,4]$。
- 对于 $S=[1,3,2,1]$,Simons 选择 $[1,4]$。
- 对于 $S=[2,1,1,3]$,Simons 选择 $[1,2]$ 和 $[3,4]$。
- 对于 $S=[2,1,3,1]$,Simons 选择 $[1,2]$、$[3,3]$ 和 $[4,4]$。
- 对于 $S=[3,2,1,1]$,Simons 选择 $[1,3]$ 和 $[4,4]$。
由 ChatGPT 5 翻译