#aBC304F. [ABC304F] Shift Table

[ABC304F] Shift Table

AT_abc304_f [ABC304F] Shift Table

题目描述

高桥君和青木君将在接下来的 NN 天里做兼职。
高桥君的排班表由字符串 SS 给出,SS 的第 ii 个字符为 # 时表示第 ii 天上班,为 . 时表示第 ii 天不上班。
基于此,青木君按照如下方式制作了自己的排班表:

  • 首先,取 NN 的一个正因数 MM,但 MNM \neq N
  • 接着,决定第 11 天到第 MM 天的出勤情况。
  • 最后,依次对 i=1,2,,NMi = 1, 2, \ldots, N - M,令第 M+iM + i 天的出勤情况与第 ii 天相同。

需要注意的是,即使 MM 的取值不同,最终得到的排班表也可能相同。

请计算,在 NN 天中,每一天高桥君和青木君至少有一人上班的情况下,青木君的排班表可能有多少种,结果对 998244353998244353 取模。

输入格式

输入以如下格式从标准输入读入。

NN SS

输出格式

请输出答案。

输入输出样例 #1

输入 #1

6
##.#.#

输出 #1

3

输入输出样例 #2

输入 #2

7
...####

输出 #2

1

输入输出样例 #3

输入 #3

12
####.####.##

输出 #3

19

说明/提示

限制条件

  • NN2210510^5 之间的整数。
  • SS 是长度为 NN 的、仅由 #. 组成的字符串。

样例解释 1

高桥君在第 1,2,4,61, 2, 4, 6 天上班。用字符串 TT 表示青木君的排班表,TT 的第 ii 个字符为 # 时表示第 ii 天上班,为 . 时表示第 ii 天不上班。可能的 TT#######.#.#..##.##33 种。第 11 种排班表可以通过 M=1M = 12233 实现,第 22 种排班表可以通过 M=2M = 2 实现,第 33 种排班表可以通过 M=3M = 3 实现。

由 ChatGPT 4.1 翻译