AT_abc372_c [ABC372C] Count ABC Again

题目描述

给定一个长度为 $N$ 的字符串 $S$。接着给出 $Q$ 个查询,依次处理。 对于第 $i$ 个查询: - 给定一个整数 $X_i$ 和一个字符 $C_i$,将 $S$ 的第 $X_i$ 个字符替换为 $C_i$。然后,输出字符串 $S$ 中包含 `ABC` 作为子串的次数。 这里,$S$ 的 **子串** 指的是,从 $S$ 的开头删除 $0$ 个或多个字符,从 $S$ 的结尾删除 $0$ 个或多个字符后得到的字符串。 例如,`ab` 是 `abc` 的子串,但 `ac` 不是 `abc` 的子串。

输入格式

输入按以下形式从标准输入给出: > $ N $ $ Q $ $ S $ $ X_1 $ $ C_1 $ $ X_2 $ $ C_2 $ $ \vdots $ $ X_Q $ $ C_Q $

输出格式

输出 $Q$ 行。第 $i$ 行 $(1 \le i \le Q)$ 包含第 $i$ 个查询的答案。

说明/提示

### 约束 - $3 \le N \le 2×10^5$ - $1 \le Q \le 2×10^5$ - $S$ 是由大写字母组成的长度为 $N$ 的字符串 - $1 \le Xi \le N$ - $C_i$ 是大写字母 ### 示例解释 1 处理每个查询后的 $S$ 如下: - 处理第 $1$ 个查询后:$S$ 变为 `ABCBABC`。其中 `ABC` 作为子串出现了 $2$ 次。 - 处理第 $2$ 个查询后:$S$ 变为 `ABABABC`。其中 `ABC` 作为子串出现了 $1$ 次。 - 处理第 $3$ 个查询后:$S$ 变为 `ABABCBC`。其中 `ABC` 作为子串出现了 $1$ 次。 - 处理第 $4$ 个查询后:$S$ 变为 `ABAGCBC`。其中 `ABC` 作为子串出现了 $0$ 次。 ### 示例解释 2 有时处理查询前后 $S$ 可能不会发生变化。