#dwacon5thprelimsc. [dwacon5th_prelims_c]k-DMC

[dwacon5th_prelims_c]k-DMC

問題文

ドワンゴのコンテンツ配信基盤システム Dwango Media Cluster は、略して DMC と呼ばれています。
この名前をかっこ良いと感じたニワンゴくんは、文字列の DMC らしさを数値として定義することにしました。
具体的には、長さ NN のある文字列 SS と3以上の整数 kk が与えられた時、以下を満たす整数の3つ組 (a,b,c)(a,b,c) の個数を SSkk-DMC 数と呼ぶことにします。

  • 0leqa<b<cleqN10 \\leq a < b < c \\leq N - 1
  • S\[a\] = D
  • S\[b\] = M
  • S\[c\] = C
  • ca<kc-a < k

ここで、S\[a\]SSaa 番目の文字を表します。先頭の文字は 00 文字目として扱います (つまり、0leqaleqN10 \\leq a \\leq N - 1 です)。

ある文字列 SSQQ 個の整数 k0,k1,...,kQ1k_0, k_1, ..., k_{Q-1} に対して、kik_i-DMC 数をそれぞれ計算してください。

制約

  • 3leqNleq1063 \\leq N \\leq 10^6
  • SSA - Z からなる文字列
  • 1leqQleq751 \\leq Q \\leq 75
  • 3leqkileqN3 \\leq k_i \\leq N
  • 入力として与えられる数値はすべて整数である

入力

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

NN SS QQ k0k_{0} k1k_{1} ...... kQ1k_{Q-1}

出力

QQ 行出力せよ。
ii 行目 (0leqileqQ1)(0 \\leq i \\leq Q-1) には、文字列 SSkik_i-DMC 数を出力せよ。


入力例1

18
DWANGOMEDIACLUSTER
1
18

出力例1

1

(a,b,c)=(0,6,11)(a,b,c) = (0, 6, 11) が条件を満たします。
Dwango Media Cluster は、ニワンゴくんの定義では意外と DMC らしくないようです。


入力例2

18
DDDDDDMMMMMCCCCCCC
1
18

出力例2

210

6times5times76\\times 5\\times 7 個の組み合わせがありえます。


入力例3

54
DIALUPWIDEAREANETWORKGAMINGOPERATIONCORPORATIONLIMITED
3
20 30 40

出力例3

0
1
2

ca<kic-a < k_i 以外の条件は (a,b,c)=(0,23,36),(8,23,36)(a, b, c) = (0, 23, 36), (8, 23, 36) が満たします。
ちなみに、DWANGO は「Dial-up Wide Area Network Gaming Operation」の頭文字です。


入力例4

30
DMCDMCDMCDMCDMCDMCDMCDMCDMCDMC
4
5 10 15 20

出力例4

10
52
110
140