#aBC158E. [ABC158E] Divisible Substring

[ABC158E] Divisible Substring

AT_abc158_e [ABC158E] Divisible Substring

题目描述

高桥君有一个由数字 0099 组成、长度为 NN 的字符串 SS

高桥君喜欢素数 PP,他想知道,在 SS 的所有 N×(N+1)/2N \times (N + 1) / 2 个非空连续子串中,有多少个子串在视为十进制整数时能够被 PP 整除。

注意,子串可以以 00 开头;即使作为字符串或整数相等,只要在 SS 中的位置不同,也要分别计数。

请你帮高桥君计算这个数量。

输入格式

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

NN PP SS

输出格式

输出 SS 的所有非空连续子串中,能被 PP 整除的子串的个数。

输入输出样例 #1

输入 #1

4 3
3543

输出 #1

6

输入输出样例 #2

输入 #2

4 2
2020

输出 #2

10

输入输出样例 #3

输入 #3

20 11
33883322005544116655

输出 #3

68

说明/提示

限制条件

  • 1N2×1051 \leq N \leq 2 \times 10^5
  • SS 只包含数字
  • S=N|S| = N
  • 2P100002 \leq P \leq 10000
  • PP 是素数

样例解释 1

S=3543S = 3543SS 的所有非空连续子串共有 1010 个,如下所示:

  • 3 可以被 33 整除。
  • 35 不能被 33 整除。
  • 354 可以被 33 整除。
  • 3543 可以被 33 整除。
  • 5 不能被 33 整除。
  • 54 可以被 33 整除。
  • 543 可以被 33 整除。
  • 4 不能被 33 整除。
  • 43 不能被 33 整除。
  • 3 可以被 33 整除。

其中能被 33 整除的有 66 个,所以输出 66

样例解释 2

S=2020S = 2020SS 的所有非空连续子串共有 1010 个,并且全部都能被 22 整除,所以输出 1010。注意允许以 00 开头的子串。

由 ChatGPT 4.1 翻译