loj#P2030. 「SDOI2016」储能表

「SDOI2016」储能表

题目描述

有一个 n n m m 列的表格,行从 0 0 n1 n - 1 编号,列从 0 0 m1 m - 1 编号。
每个格子都储存着能量。最初,第 i i 行第 j j 列的格子储存着 (ixorj) (i \mathbin{\text{xor}} j) 点能量。所以,整个表格储存的总能量是,

$$\sum\limits_{i = 0} ^ {n - 1} \sum\limits_{j = 0} ^ {m - 1} (i \mathbin{\text{xor}} j) $$

随着时间的推移,格子中的能量会渐渐减少。一个时间单位,每个格子中的能量都会减少 1 1 。显然,一个格子的能量减少到 0 0 之后就不会再减少了。
也就是说,k k 个时间单位后,整个表格储存的总能量是,

$$\sum\limits_{i = 0} ^ {n - 1} \sum\limits_{j = 0} ^ {m - 1} \max((i \mathbin{\text{xor}} j) - k, 0) $$

给出一个表格,求 k k 个时间单位后它储存的总能量。
由于总能量可能较大,输出时对 p p 取模。

输入格式

第一行一个整数 T T ,表示数据组数。
接下来 T T 行,每行四个整数 n n m m k k p p

输出格式

TT 行,每行一个数,表示总能量对 pp 取模后的结果。

3
2 2 0 100
3 3 0 100
3 3 1 100
2
12
6

数据范围与提示

测试点 1 ~ 2:T=5000 T = 5000 n100 n \leq 100 m100 m \leq 100 k100 k \leq 100 p109 p \leq 10 ^ 9
测试点 3:T=5000 T = 5000 n1018 n \leq 10 ^ {18} m1018 m \leq 10 ^ {18} k=0 k = 0 p109 p \leq 10 ^ 9
测试点 4:T=5000 T = 5000 n1018 n \leq 10 ^ {18} m1018 m \leq 10 ^ {18} k=1 k = 1 p109 p \leq 10 ^ 9
测试点 5:T=5000 T = 5000 n10 n \leq 10 m1018 m \leq 10 ^ {18} k10 k \leq 10 p109 p \leq 10 ^ 9
测试点 6:T=1 T = 1 n105 n \leq 10 ^ 5 m1018 m \leq 10 ^ {18} k105 k \leq 10 ^ 5 p109 p \leq 10 ^ 9
测试点 7:T=1 T = 1 n1018 n \leq 10 ^ {18} m1018 m \leq 10 ^ {18} k1018 k \leq 10 ^ {18} p109 p \leq 10 ^ 9
测试点 8:T=100 T = 100 n1018 n \leq 10 ^ {18} m1018 m \leq 10 ^ {18} k1018 k \leq 10 ^ {18} p109 p \leq 10 ^ 9
测试点 9 ~ 10:T=5000 T = 5000 n1018 n \leq 10 ^ {18} m1018 m \leq 10 ^ {18} k1018 k \leq 10 ^ {18} p109 p \leq 10 ^ 9