CF1234D Distinct Characters Queries
题目描述
给定一个只包含小写拉丁字母的字符串 $s$,以及 $q$ 个关于该字符串的查询。
回忆一下,字符串 $s[l; r]$ 的子串是 $s_l s_{l + 1} \dots s_r$。例如,"codeforces" 的子串有 "code"、"force"、"f"、"for",但没有 "coder" 和 "top"。
查询有两种类型:
- $1~ pos~ c$($1 \le pos \le |s|$,$c$ 为小写拉丁字母):将 $s_{pos}$ 替换为 $c$(即 $s_{pos} := c$);
- $2~ l~ r$($1 \le l \le r \le |s|$):计算子串 $s[l; r]$ 中不同字符的数量。
输入格式
第一行输入一个字符串 $s$,由不超过 $10^5$ 个小写拉丁字母组成。
第二行输入一个整数 $q$($1 \le q \le 10^5$),表示查询的数量。
接下来的 $q$ 行,每行一个查询,格式如题目描述所示。保证至少有一个第二类查询。
输出格式
对于每个第二类查询,输出该查询所要求的子串中不同字符的数量。
说明/提示
由 ChatGPT 4.1 翻译