CF2187D Cool Problem
题目描述
有两个整数常数 $x$ 和 $y$。
对于一个长度为 $n$ 的二进制字符串 $r$,我们定义它的生成数组为 $c=[c_0,c_1,\ldots,c_n]$,其中 $c_0=0$,并且对每个 $1 \le i \le n$:
- 如果 $r_i=\mathtt{0}$,那么 $c_i=x+c_{i-1}$;
- 如果 $r_i=\mathtt{1}$,那么 $c_i=y-c_{i-1}$。
此外,我们定义 $f(r)=\sum\limits_{i=1}^n c_i$。
现在给定一个长度为 $n$ 的不完整二进制字符串 $s$,其中有些字符缺失,用 $\mathtt{?}$ 表示。若存在一种方式将 $s$ 中的每个 $\mathtt{?}$ 替换成 $\mathtt{0}$ 或 $\mathtt{1}$,使得 $f(s)=k$,那么整数 $k$ 被称为“cool”整数。
你的任务是计算所有 cool 整数的和,结果对 $998\,244\,353$ 取模。
输入格式
每组测试数据包含多个测试用例。第一行包含一个整数 $t$($1 \le t \le 10^4$),表示测试用例的数量。每个测试用例的描述如下。
每个测试用例的第一行包含三个整数 $n$、$x$ 和 $y$($1 \le n \le 10^5$,$1 \le x,y \le 10^6$),分别表示字符串 $s$ 的长度和两个给定的常数。
第二行包含长度为 $n$ 的不完整二进制字符串 $s$($s_i \in \{\mathtt{0},\mathtt{1},\mathtt{?}\}$)。
保证所有测试用例中 $n$ 的总和不超过 $10^5$。
输出格式
对于每个测试用例,输出一个整数,表示所有 cool 整数之和,对 $998\,244\,353$ 取模。
说明/提示
在第一个测试用例中,字符串 $s$ 已经确定,其生成数组为 $[0, 1]$。因此 $f(s)=1$,唯一的 cool 整数为 $1$。
在第三个测试用例中,有四种方式补全字符串 $s$:
| $s$ | 生成数组 | $f(s)$ |
|---------|---------------------|--------|
| $\mathtt{000}$ | $[0, 7, 14, 21]$ | $42$ |
| $\mathtt{001}$ | $[0, 7, 14, -9]$ | $12$ |
| $\mathtt{100}$ | $[0, 5, 12, 19]$ | $36$ |
| $\mathtt{101}$ | $[0, 5, 12, -7]$ | $10$ |
因此,所有 cool 整数之和为 $42+12+36+10=100$。
由 ChatGPT 5 翻译