A85777.「TJOI2018」异或

省选/NOI-

通过率:0%

时间限制:3.00s

内存限制:256MB

题目描述

现在有一颗以 11 为根节点的由 nn 个节点组成的树,树上每个节点上都有一个权值 viv_i 。现在有 QQ 次操作,操作如下:

  • 1 x y :查询节点 xx 的子树中与 yy 异或结果的最大值。
  • 2 x y z :查询路径 xxyy 上点与 zz 异或结果最大值

输入格式

第一行是两个数字 nn , QQ
第二行是 nn 个数字用空格隔开,第 ii 个数字 viv_i 表示点 ii 上的权值。
接下来 n1n-1 行,每行两个数, x,yx,y ,表示节点 xxyy 之间有边。
接下来 QQ 行,每一行为一个查询,格式如上所述。

输出格式

对于每一个查询,输出一行,表示满足条件的最大值。

输入输出样例

  • 输入#1

    7 5
    1 3 5 7 9 2 4
    1 2
    1 3
    2 4
    2 5
    3 6
    3 7
    1 3 5
    2 4 6 3
    1 5 5
    2 5 7 2
    1 1 9

    输出#1

    7
    6
    12
    11
    14

说明/提示

对于 10%10\% 的数据,有 1n,Q1001 \le n, Q \leq 100
对于 20%20\% 的数据,有 1n,Q10001 \le n, Q \leq 1000
对于 40%40\% 的数据,有 1n,Q100001 \le n, Q \leq 10000
对于 100%100\% 的数据,有 1n,Q1000001 \le n, Q \leq 100000 ,查询 1 中的 y230y \leq 2^{30} ,查询 2 中的 z230z \leq 2^{30}

首页