Home => ProblemSet => 3.2-15:可持久化线段树 1(可持久化数组)
Problem1810--3.2-15:可持久化线段树 1(可持久化数组)

1810: 3.2-15:可持久化线段树 1(可持久化数组)

Time Limit: 2 Sec  Memory Limit: 1024 MB  Submit: 0  Solved: 5
[ Submit ] [ Status ] [ Creator: ][ 参考程序 ]

Description

如题,你需要维护这样的一个长度为 N 的数组,支持如下几种操作
  1. 在某个历史版本上修改某一个位置上的值
  2. 访问某个历史版本上的某一位置的值
此外,每进行一次操作(对于操作2,即为生成一个完全一样的版本,不作任何改动),就会生成一个新的版本。版本编号即为当前操作的编号(从1开始编号,版本0表示初始状态数组)

Input

输入的第一行包含两个正整数 N,M, 分别表示数组的长度和操作的个数。
第二行包含 N个整数,依次为初始状态下数组各位的值(依次为 ai,1≤i≤N)。
接下来 M行每行包含3或4个整数,代表两种操作之一(i为基于的历史版本号):
  1. 对于操作1,格式为vi 1 aloci valuei,即为在版本 vi的基础上,将 aloci 修改为 valuei
  2. 对于操作2,格式为 vi 2 aloci,即访问版本 vi中的 aloci的值,生成一样版本的对象应为vi

Output

输出包含若干行,依次为每个操作2的结果。

Sample Input Copy

5 10
59 46 14 87 41
0 2 1
0 1 1 14
0 1 1 57
0 1 1 88
4 2 4
0 2 5
0 2 4
4 2 1
2 2 2
1 1 5 91

Sample Output Copy

59
87
41
87
88
46

HINT



数据规模:
对于30%的数据:1≤N,M≤103
对于50%的数据:1≤N,M≤104
对于70%的数据:1≤N,M≤105
对于100%的数据:1≤N,M≤106,1≤loci≤N,0≤vi<i,−109≤ai,valuei≤109




询问生成的版本是指你访问的那个版本的复制

样例说明:

一共11个版本,编号从0-10,依次为:

0 : 59 46 14 87 41

1 : 59 46 14 87 41

2 : 14 46 14 87 41

3 : 57 46 14 87 41

4 : 88 46 14 87 41

5 : 88 46 14 87 41

6 : 59 46 14 87 41

7 : 59 46 14 87 41

8 : 88 46 14 87 41

9 : 14 46 14 87 41

10 : 59 46 14 87 91



Source/Category