#ATagc033e. [AGC033E] Go around a Circle

[AGC033E] Go around a Circle

题目描述

一个圆周被 NN 个点等分,每个点之间的圆弧被涂成红色或蓝色。我们说,这个圆可以从所有点出发生成一个由 RB 组成、长度为 MM 的字符串 SS,当且仅当满足以下条件:

  • 从圆周上的 NN 个点中任选一个点,将棋子放在该点上。
  • 将棋子沿顺时针或逆时针方向移动到相邻的点,如此重复 MM 次。
  • 无论最初选择哪个点,都可以通过选择合适的移动方向,使得第 ii 次经过的圆弧颜色为 SiS_i

其中,SiS_iR 时表示红色,为 B 时表示蓝色。注意,每次选择的起点可以独立选择移动方向。

现在给定一个由 RB 组成、长度为 MM 的字符串 SS。请计算将圆周等分为 NN 的每个圆弧涂成红色或蓝色的 2N2^N 种方法中,有多少种方法可以使得 SS 能从所有点出发生成。请输出答案对 109+710^9+7 取模的结果。

注意,旋转后相同的涂色方案也要分别计数。

输入格式

输入为一行,包含:

NN MM SS

输出格式

输出满足条件的涂色方案数对 109+710^9+7 取模的结果。

样例 1

输入

4 7
RBRRBRR

输出

2

样例 2

输入

3 3
BBB

输出

4

样例 3

输入

12 10
RRRRBRRRRB

输出

78

说明/提示

限制条件

  • 2N2×1052 \leq N \leq 2 \times 10^5
  • 1M2×1051 \leq M \leq 2 \times 10^5
  • S=M|S| = M
  • SiS_iRB

样例解释 1

只有当红色和蓝色交替涂色时,才能满足条件。因此,这种情况下答案为 22

由 ChatGPT 4.1 翻译