luogu#P6215. 函数求值

函数求值

题目描述

有两个长度均为 nn 的权值序列 a,ba,b,常数 p,kp,k,以及两个函数:

g(x)=i=1xpi×aig(x) = \sum_{i=1}^x p^i \times a_i f(x)=i=1xg(i)k×bif(x) = \sum_{i=1}^x g(i) ^ k \times b_i

mm 个操作,操作有以下三种:

  • 1 x y1\ x\ y,表示将 axa_x 修改为 yy

  • 2 x y2\ x\ y,表示将 bxb_x 修改为 yy

  • 3 x3\ x,表示查询 f(x)f(x)109+710 ^ 9 + 7 取模的值。

输入格式

第一行四个整数,n,m,p,kn,m,p,k

第二行 nn 个整数,表示序列 aa

第三行 nn 个整数,表示序列 bb

接下来 mm 行,每行描述一个操作。

输出格式

对于每个 3 x3\ x 操作,输出答案。

10 10 1 1
0 1 8 8 5 6 6 8 0 1 
9 2 8 8 6 2 5 0 1 8 
3 9
1 2 3
3 10
3 5
2 10 0
3 10
1 5 9
2 9 7
3 9
3 4

610
1034
390
674
1018
246

10 10 873892251 2
393158301 365328187 234823508 38818450 963771276 826653462 358628534 626503513 239326879 647251399 
1 1 1 1 1 1 1 1 1 1 
1 6 861625956
1 2 300158647
1 2 84103073
3 8
1 1 942644245
1 9 883742604
1 2 974963615
3 5
1 8 710319943
3 1

35415628
483475596
154061492

10 10 480345252 3
494173949 364489100 93066339 249297520 207335443 117096873 864460454 113006173 214332928 582507765 
5658914 222040024 221653308 296560771 594076100 151232714 410372721 23331041 374481229 184401699 
3 6
3 8
1 1 931776921
1 6 44943479
1 6 946828878
1 4 9046748
3 3
1 7 692410213
1 10 483672045
3 10

214010503
321766325
894782746
274293582

提示

【样例解释】

这是样例一操作四后的结果:

// 11 22 33 44 55
aia_i 00 33 88 55
bib_i 99 22 66
g(i)g(i) 00 33 1111 1919 2424
f(i)f(i) 66 9494 246246 390390

【数据范围】

  • 对于 100%100\%% 的数据:

    1n,m2×1051 \le n,m \le 2 \times 10 ^ 5

    0ai,bi,p109+60 \le a_i,b_i,p \le 10 ^ 9 + 6

    1xn1 \le x \le n0y109+60 \le y \le 10 ^ 9 + 6

    1k31 \le k \le 3

  • 详细的数据范围:

    测试点编号 n,mn,m \le kk 特殊性质
    11 300300 3\le 3
    22
    33 3×1033 \times 10 ^ 3
    44
    55 7×1047 \times 10 ^ 4 =1= 1 A
    66
    77
    88 =2= 2
    99 =3= 3
    1010 =1= 1 B
    1111
    1212 =2= 2
    1313 =3= 3
    1414
    1515 =1= 1
    1616 =2= 2
    1717 =3= 3
    1818 2×1052 \times 10 ^ 5 =1= 1
    1919 =2= 2
    2020 =3= 3

    A:任意时刻所有 bi=1b_i = 1

    B:无操作二。


【提示】

样例二满足A类性质,样例三满足B类性质。