#ABC304F. [ABC304F] Shift Table

[ABC304F] Shift Table

题目描述

高橋君と青木君は、これから N N 日間アルバイトをします。
高橋君のシフト表は文字列 S S により与えられ、S S i i 文字目が # のとき i i 日目に出勤、. のとき i i 日目に欠勤します。
これをもとに、青木君は以下のようにシフト表を作りました。

  • まず、N N でない N N の正の約数 M M をとる。
  • 次に、1 1 日目から M M 日目までの勤怠を決める。
  • 最後に、i = 1, 2, , N  M i\ =\ 1,\ 2,\ \ldots,\ N\ -\ M の順に M + i M\ +\ i 日目の勤怠が i i 日目の勤怠と一致するように M + i M\ +\ i 日目の勤怠を決める。

ここで、M M の値が異なる場合でも最終的にできたシフトが同じものとなることがあることに注意してください。

N N 日すべてについて高橋君と青木君の少なくとも一方が出勤することになったとき、青木君のシフト表として考えられるものの個数を 998244353 998244353 で割った余りを求めてください。

输入格式

入力は以下の形式で標準入力から与えられる。

N N S S

输出格式

答えを出力せよ。

题目大意

给出长度为 2n1052\le n\le 10^5 仅由 #. 的字符串 ss,对于任意的 mn(0<m<n)m|n(0<m<n),你可以决定字符串 tt 的前 mm 个位置是 # 还是 .,对于第 i>mi>m 个位置,字符与第 imi-m 个位置相同。要求对于位置 1in1\le i\le n 字符串 sstt 必须有一个是 #。注意不同的 mm 可能有相同的方案。问 tt 的方案数对 998244353998244353 取模的结果。

6
##.#.#
3
7
...####
1
12
####.####.##
19

提示

制約

  • N N 2 2 以上 105 10^5 以下の整数
  • S S は 長さ N N #. からなる文字列

Sample Explanation 1

高橋君は 1  2  4  6 1\ \cdot\ 2\ \cdot\ 4\ \cdot\ 6 日目に出勤します。 青木君のシフト表を表す文字列を T T とし、青木君は T T i i 文字目が # のとき i i 日目に出勤、. のとき i i 日目に欠勤するとします。 T T としてあり得るものは ###### \cdot #.#.#. \cdot .##.##3 3 つです。 1 1 つめのシフト表は M M 1 1 または 2 2 または 3 3 2 2 つめのシフト表は M = 2 M\ =\ 2 3 3 つめのシフト表は M = 3 M\ =\ 3 とすることにより実現できます。