A85984.「RCOI2019」维护

省选/NOI-

通过率:0%

时间限制:1.00s

内存限制:256MB

题目描述

题目来源:「RCOI2019」Rochine Round 1

维护一颗以 11 为根的树的形态,要求支持插入叶子节点、删除任意结点以及查询 kk 代祖先。为了尽量简单,删除时,直接让这个点的儿子替代它就好(即,全部接到父节点上)。初始时,树仅有根节点 11

输入格式

第一行两个整数 qqonline\text{online}qq 表示操作数,online=1\text{online}=1 说明本测试点强制在线。

请认真阅读下面的输入格式,稍有不慎即会 WA

对于三种操作, 若询问的 xx 已经被删除或 xx 大于节点总数或 x=0x=0,则 lastans\text{lastans} 也不要更新。

接下来 qq 行,分为三种情况(lastans\text{lastans} 初值为 00):

  • 插入操作,格式为 1 x

    • 首先,执行 xx xor lastansx\leftarrow x\ \mathrm{xor}\ \text{lastans}
    • 然后,增加一个编号为已经加入过的结点总数 +1+1 的节点作为 xx 的儿子。
    • online=1\text{online}=1,则 lastans\text{lastans} 更新为 xx,若 xx 已经被删除则不应新增任何节点。
  • 删除操作,格式为 2 x

    • 首先,执行 xx xor lastansx\leftarrow x\ \mathrm{xor}\ \text{lastans}
    • 然后删除 xx,若不存在请忽略。
    • online=1\text{online}=1,则 lastans\text{lastans} 更新为 xx 的父亲,保证 x1x\ne 1
  • 查询操作,格式为 3 x y

    • 首先,执行 xx xor lastansx\leftarrow x\ \mathrm{xor}\ \text{lastans}yy xor lastansy\leftarrow y\ \mathrm{xor}\ \text{lastans}
    • 然后输出 xxyy 代祖先。
    • online=1\text{online}=1,则 lastans\text{lastans} 更新为答案,若 xx 被删除了则什么都不要输出,若不存在则答案为 00

输出格式

输出一些行,每行一个整数,表示询问的答案。

输入输出样例

  • 输入#1

    8 0
    1 1
    1 2
    1 3
    3 4 2
    2 3
    3 4 2
    2 2
    3 4 2

    输出#1

    2
    1
    0
  • 输入#2

    4 0
    1 1
    2 2
    3 2 0
    3 1 0

    输出#2

    1
  • 输入#3

    20 1
    1 1
    1 3
    1 1
    3 7 1
    3 6 1
    3 5 3
    1 6
    1 1
    1 1
    1 3
    3 15 1
    3 8 3
    3 11 2
    1 1
    1 14
    1 0
    1 3
    3 7 10
    3 7 8
    3 11 5

    输出#3

    2
    1
    2
    0
    3
    7
    11
    7
    8

说明/提示

对于所有数据,1q2×105,online{0,1}1\le q\le 2\times 10^5,\text{online}\in\{0,1\}。详细数据范围如下。

测试点编号 qq online\text{online} 特殊性质 每测试点分数
131\sim 3 2020 11 数据随机生成 33
4,54,5 2020 00 数据随机生成 33
686\sim 8 200200 11 数据随机生成 33
9,109,10 200200 00 数据随机生成 33
11,1211,12 2×1042\times 10^4 11 数据随机生成 33
131513\sim 15 2×1042\times 10^4 00 数据随机生成 33
161916\sim 19 2×1052\times 10^5 00 44
2020 2×1052\times 10^5 11 无删除操作 99
212521\sim 25 2×1052\times 10^5 11 66

对于 q2×104q\le 2\times 10^4 的测试点,按点计分;其他测试点,按特殊性质对应 Subtask 捆绑计分

首页