CF1401F Reverse and Swap

题目描述

给定一个长度为 $2^n$ 的数组 $a$,你需要对其进行 $q$ 次操作。每次操作有以下四种类型之一: 1. $Replace(x, k)$ —— 将 $a_x$ 修改为 $k$; 2. $Reverse(k)$ —— 对所有 $i$($i \ge 1$),将子数组 $[(i-1) \cdot 2^k+1,\, i \cdot 2^k]$ 进行反转; 3. $Swap(k)$ —— 对所有 $i$($i \ge 1$),交换子数组 $[(2i-2) \cdot 2^k+1,\, (2i-1) \cdot 2^k]$ 和 $[(2i-1) \cdot 2^k+1,\, 2i \cdot 2^k]$; 4. $Sum(l, r)$ —— 输出子数组 $[l, r]$ 的元素和。 请编写程序高效地处理所有操作。

输入格式

第一行包含两个整数 $n$、$q$($0 \le n \le 18$;$1 \le q \le 10^5$),分别表示数组 $a$ 的长度的对数和操作次数。 第二行包含 $2^n$ 个整数 $a_1, a_2, \ldots, a_{2^n}$($0 \le a_i \le 10^9$)。 接下来的 $q$ 行,每行一个操作,格式如下: - “$1\ x\ k$” ($1 \le x \le 2^n$;$0 \le k \le 10^9$)—— $Replace(x, k)$; - “$2\ k$” ($0 \le k \le n$)—— $Reverse(k)$; - “$3\ k$” ($0 \le k < n$)—— $Swap(k)$; - “$4\ l\ r$” ($1 \le l \le r \le 2^n$)—— $Sum(l, r)$。 保证至少有一个 $Sum$ 操作。

输出格式

对于每个 $Sum$ 操作,输出一行答案。

说明/提示

在第一个样例中,初始数组 $a$ 为 $\{7,4,9,9\}$。 处理第一个操作后,数组 $a$ 变为 $\{7,8,9,9\}$。 处理第二个操作后,数组 $a$ 变为 $\{9,9,7,8\}$。 因此,第三个操作的答案为 $9+7+8=24$。 在第二个样例中,初始数组 $a$ 为 $\{7,0,8,8,7,1,5,2\}$。之后的操作如下: 1. $Sum(3, 7)$ $\to$ $8 + 8 + 7 + 1 + 5 = 29$; 2. $Reverse(1)$ $\to$ $\{0,7,8,8,1,7,2,5\}$; 3. $Swap(2)$ $\to$ $\{1,7,2,5,0,7,8,8\}$; 4. $Sum(1, 6)$ $\to$ $1 + 7 + 2 + 5 + 0 + 7 = 22$; 5. $Reverse(3)$ $\to$ $\{8,8,7,0,5,2,7,1\}$; 6. $Replace(5, 16)$ $\to$ $\{8,8,7,0,16,2,7,1\}$; 7. $Sum(8, 8)$ $\to$ $1$; 8. $Swap(0)$ $\to$ $\{8,8,0,7,2,16,1,7\}$。 由 ChatGPT 4.1 翻译