CF2195B Heapify 1

题目描述

给定一个长度为 $n$ 的排列 $a$。 你可以进行如下操作任意次(可以为零次): - 选择一个下标 $i$($1 \le i \le \frac{n}{2}$),交换 $a_i$ 和 $a_{2i}$。 例如,当 $a=[1,4,2,3,5]$ 时,你可以交换 $a_2$ 和 $a_4$ 使其变为 $[1,3,2,4,5]$,但你不能交换 $a_2$ 和 $a_3$。 请你判断,是否可以通过若干次上述操作将序列 $a$ 排成升序。 一个长度为 $n$ 的排列是一个由 $1$ 到 $n$ 的 $n$ 个互不相同的整数组成的数组。例如,$[2,3,1,5,4]$ 是一个排列,但 $[1,2,2]$ 不是排列($2$ 在数组中出现了两次),$[1,3,4]$ 也不是排列($n=3$ 但数组中有 $4$)。

输入格式

每组测试数据包含多个测试用例。第一行包含测试用例组数 $t$($1 \le t \le 10^4$)。接下来是各组测试用例的描述。 每个测试用例的第一行包含一个整数 $n$($1 \le n \le 2 \cdot 10^5$)。 第二行包含 $n$ 个不同的整数 $a_1, a_2, \ldots, a_n$($1 \le a_i \le n$)。 保证所有测试用例中 $n$ 的总和不超过 $2 \cdot 10^5$。

输出格式

如果 $a$ 可以升序排列,则输出一行 “YES”。否则输出一行 “NO”。 输出答案时不区分大小写。例如,字符串 "yEs"、"yes" 和 "Yes" 都被视为肯定回答。

说明/提示

在第一个测试用例中,$a = [1,4,3,2,5]$。你可以通过交换 $a_2$ 和 $a_4$ 将 $a$ 排成升序。因此答案为 “YES”。 在第二个测试用例中,$a = [1,4,2,3,5]$。无论如何都无法排成升序。因此答案为 “NO”。 由 ChatGPT 5 翻译