#P6074. 「2017 山东一轮集训 Day6」子序列

「2017 山东一轮集训 Day6」子序列

题目描述

给定一个长度为 n n 的只包含前 9 9 个小写字母的字符串 s s q q 个询问 l,r l,r ,询问 s[lr] s[l \ldots r] 中有多少本质不同的子序列。答案对 109+7 10 ^ 9 + 7 取模。
s[lr] s[l \ldots r] 的子序列 {p1,p2,,pk} \{ p_1, p_2, \cdots, p_k \} 需要满足:lp1<p2<<pkr l \leq p_1 < p_2 < \cdots < p_k \leq r
两个子序列 p,q p, q 是本质不同的,当且仅当其长度不同,或存在一个 i i ,满足 s[pi]s[qi] s[p_i] \neq s[q_i]

输入格式

第一行一个字符串 s s
第二行一个整数 q q
接下来 q q 行描述一个询问 li,ri l_i, r_i

输出格式

输出 q q 行,依次表示每个询问的答案。

bacbbab
3
4 6
1 7
1 3
5
68
7

数据范围与提示

对于 20% 20\% 的数据,n20 n \leq 20
对于 40% 40\% 的数据,n1000 n \leq 1000
对于 60% 60\% 的数据,n10000 n \leq 10000
对于 100% 100\% 的数据,1n,q100000,1lrn 1 \leq n, q \leq 100000, 1 \leq l \leq r \leq n