A93010.「NOI2021」密码箱
NOI/NOI+/CTSC
通过率:0%
时间限制:2.00s
内存限制:1024MB
题目描述
Yelekastee 是 U 国著名的考古学家。在最近的一次考古行动中,他发掘出了一个远古时期的密码箱。经过周密而严谨的考证,Yelekastee 得知密码箱的密码和某一个数列 {an} 相关。数列 {an} 可以用如下方式构造出来:
- 初始时数列长度为 2 且有 a0=0,a1=1;
- 对数列依次进行若干次操作,其中每次操作是以下两种类型之一:
W类型:给数列的最后一项加 1。E类型:若数列的最后一项为 1,则给倒数第二项加 1;否则先给数列的最后一项减 1,接着在数列尾再加两项,两项的值都是 1。
受到技术限制,密码箱并没有办法完整检查整个数列,因此密码箱的密码设定为数列 {an} 经过函数 f 作用后的值,其中 f 的定义如下:
f(a0,…,ak−1,ak)={a0,f(a0,a1,…,ak−2,ak−1+ak1),k=0k≥1
Yelekastee 并不擅长运算,因此他找到了你,希望你能根据他提供的操作序列计算出密码箱的密码。不幸的是,他的记性并不是很好,因此他会随时对提供的操作序列做出一些修改,这些修改包括以下三种:
APPEND c,在现有操作序列后追加一次c类型操作,其中c为字符W或E。FLIP l r,反转现有操作序列中第 l 个至第 r 个(下标从 1 开始,修改包含端点 l 和 r,下同)操作,即所有W变为E,所有E变为W。REVERSE l r,翻转现有操作序列中第 l 个至第 r 个操作,也就是将这个区间中的操作逆序。
输入格式
从文件 code.in 读入数据。
输入第一行包含两个正整数 n,q,分别表示初始的操作序列长度和修改的次数。
第二行包含一个长为 n 且仅包含大写字母 W 和 E 的字符串,表示初始操作序列。
接下来 q 行,每行表示一次修改。每种修改的格式如【题目描述】所述。
输出格式
输出到文件 code.out 中。
输出共 q+1 行,每行两个整数,其中第一行表示初始操作序列对应的密码,接下来 q 行则分别输出每次修改之后的操作序列对应的密码。
容易发现密码一定是正有理数。若真实的密码为 ba,其中 a,b>0 且 gcd(a,b)=1,则你需要在对应的行内顺次输出 a 和 b 模 998244353 后的余数。
输入输出样例
输入#1
2 3 WE APPEND E FLIP 1 2 REVERSE 2 3
输出#1
2 3 3 4 5 3 5 2
说明/提示
对于所有测试点:1≤n≤105,1≤q≤105。
对于 APPEND 修改,保证给出的 c 为大写英文字母 W 或 E。
对于 FLIP 和 REVERSE 修改,保证 1≤l≤r≤L,其中 L 是当前操作序列的长度。
请注意由于有 APPEND 操作,操作序列的长度最大可能有 2×105。
| 测试点编号 | n,q≤ | 特殊限制 |
|---|---|---|
| 1∼4 | 2000 | 无 |
| 5∼7 | 105 | A |
| 8∼10 | 105 | B,C |
| 11∼14 | 105 | C |
| 15∼20 | 105 | 无 |
特殊限制 A:保证在任意时刻操作序列中不会出现连续相同的两个字符。
特殊限制 B:保证没有 FLIP 修改。
特殊限制 C:保证没有 REVERSE 修改。