AT_agc033_e [AGC033E] Go around a Circle
题目描述
一个圆周被 $N$ 个点等分,每个点之间的圆弧被涂成红色或蓝色。我们说,这个圆可以从所有点出发生成一个由 `R` 和 `B` 组成、长度为 $M$ 的字符串 $S$,当且仅当满足以下条件:
- 从圆周上的 $N$ 个点中任选一个点,将棋子放在该点上。
- 将棋子沿顺时针或逆时针方向移动到相邻的点,如此重复 $M$ 次。
- 无论最初选择哪个点,都可以通过选择合适的移动方向,使得第 $i$ 次经过的圆弧颜色为 $S_i$。
其中,$S_i$ 为 `R` 时表示红色,为 `B` 时表示蓝色。注意,每次选择的起点可以独立选择移动方向。
现在给定一个由 `R` 和 `B` 组成、长度为 $M$ 的字符串 $S$。请计算将圆周等分为 $N$ 的每个圆弧涂成红色或蓝色的 $2^N$ 种方法中,有多少种方法可以使得 $S$ 能从所有点出发生成。请输出答案对 $10^9+7$ 取模的结果。
注意,旋转后相同的涂色方案也要分别计数。
输入格式
输入为一行,包含:
> $N$ $M$ $S$
输出格式
输出满足条件的涂色方案数对 $10^9+7$ 取模的结果。
说明/提示
### 限制条件
- $2 \leq N \leq 2 \times 10^5$
- $1 \leq M \leq 2 \times 10^5$
- $|S| = M$
- $S_i$ 是 `R` 或 `B`
### 样例解释 1
只有当红色和蓝色交替涂色时,才能满足条件。因此,这种情况下答案为 $2$。
由 ChatGPT 4.1 翻译