logo AlgoBeat OnlineJudge
登录 注册

#52555. [BZOJ 2555] SubString

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

题目描述

懒得写背景了,给你一个字符串 init,要求你支持两个操作:
(1) 在当前字符串的后面插入一个字符串;
(2) 询问字符串 在当前字符串中出现了几次?(作为连续子串)
你必须在线支持这些操作。

输入格式

第一行一个数 表示操作个数。
第二行一个字符串表示初始字符串 init
接下来 行,每行两个字符串 Type, Str
TypeADD 的话表示在后面插入字符串。
TypeQUERY 的话表示询问某字符串在当前字符串中出现了几次。
为了体现在线操作,你需要维护一个变量 mask,初始值为

读入串 Str 之后,使用下述过程将之解码成真正询问的串 TrueStr

String decodeWithMask(String s, int mask) {
    char[] chars = s.toCharArray();
    for (int j = 0; j < chars.length; j++) {
        mask = (mask * 131 + j) % chars.length;
        char t = chars[j];
        chars[j] = chars[mask];
        chars[mask] = t;
    }
    return new String(chars);
}

插入的时候,将 TrueStr 插到当前字符串后面即可。

输出格式

询问的时候,对 TrueStr 询问后输出一行答案 Result,然后 mask = mask xor Result

样例

Sample Input

2
A
QUERY B
ADD BBABBBBAAB

Sample Output

0

数据范围与提示

Source
Ctsc 模拟赛 By 洁妹

HINTADDQUERY 操作的字符串都需要解压。
长度 ,询问次数 ,询问总长度
新加数据一组 —— 2015.05.20