#2444. 「NOI2011」阿狸的打字机

内存限制:256 MiB 时间限制:1000 ms 标准输入输出
题目类型:传统 评测方式:文本比较
上传者: luyanaa

题目描述

阿狸喜欢收藏各种稀奇古怪的东西,最近他淘到一台老式的打字机。打字机上只有 282828 个按键,分别印有 262626 个小写英文字母和 BP 两个字母。 经阿狸研究发现,这个打字机是这样工作的:

  • 输入小写字母,打字机的一个凹槽中会加入这个字母(按 P 前凹槽中至少有一个字母)。
  • 按一下印有 B 的按键,打字机凹槽中最后一个字母会消失。
  • 按一下印有 P 的按键,打字机会在纸上打印出凹槽中现有的所有字母并换行,但凹槽中的字母不会消失(保证凹槽中至少有一个字母)。

例如,阿狸输入 aPaPBbP ,纸上被打印的字符如下:

a 
aa 
ab

我们把纸上打印出来的字符串从 111 开始顺序编号,一直到 nnn 。打字机有一个非常有趣的功能,在打字机中暗藏一个带数字的小键盘,在小键盘上输入两个数 (x,y)(x,y)(x,y) (其中 1≤x,y≤n1 \le x,y \le n1x,yn ),打字机会显示第 xxx 个打印的字符串在第 yyy 个打印的字符串中出现了多少次。
阿狸发现了这个功能以后很兴奋,他想写个程序完成同样的功能,你能帮助他么?

输入格式

输入的第一行包含一个字符串,按阿狸的输入顺序给出所有阿狸输入的字符。
第二行包含一个整数 mmm ,表示询问个数。 接下来 mmm 行描述所有由小键盘输入的询问。其中第i行包含两个整数 x,yx, yx,y ,表示第i个询问为 (x,y)(x, y)(x,y)

输出格式

输出 mmm 行,其中第 iii 行包含一个整数,表示第 iii 个询问的答案。

样例

样例输入

aPaPBbP 
3 
1 2
1 3 
2 3

样例输出

2
1
0

数据范围与提示

所有测试数据的范围和特点如下表所示:

测试点编号 nnn 的规模 mmm 的规模 字符串长度 输入总长 (输入文件第一行的字符数)
1 1≤n≤100 1\le n \le 1001n100 1≤m≤1000 1\le m \le 10001m1000 - ≤100\le 100100
2 1≤n≤100 1\le n \le 1001n100 1≤m≤1000 1\le m \le 10001m1000 - ≤100\le 100100
3 1≤n≤1000 1\le n \le 10001n1000 1≤m≤104 1\le m \le 10^41m104 单个长度 ≤1000 \le 10001000 ,总长度 ≤105 \le 10^5105 ≤105\le 10^5105
4 1≤n≤1000 1\le n \le 10001n1000 1≤m≤104 1\le m \le 10^41m104 单个长度 ≤1000 \le 10001000 ,总长度 ≤105 \le 10^5105 ≤105\le 10^5105
5 1≤n≤104 1\le n \le 10^41n104 1≤m≤105 1\le m \le 10^51m105 总长度 ≤105 \le 10^5105 ≤105\le 10^5105
6 1≤n≤104 1\le n \le 10^41n104 1≤m≤105 1\le m \le 10^51m105 总长度 ≤105 \le 10^5105 ≤105\le 10^5105
7 1≤n≤104 1\le n \le 10^41n104 1≤m≤105 1\le m \le 10^51m105 总长度 ≤105 \le 10^5105 ≤105\le 10^5105
8 1≤n≤105 1\le n \le 10^51n105 1≤m≤105 1\le m \le 10^51m105 - ≤105\le 10^5105
9 1≤n≤105 1\le n \le 10^5 1n105 1≤m≤105 1\le m \le 10^51m105 - ≤105\le 10^5105
10 1≤n≤105 1\le n \le 10^51n105 1≤m≤105 1\le m \le 10^51m105 - ≤105\le 10^5105