CFCF2195B.Heapify 1

普及/提高-

通过率:0%

AC君温馨提醒

该题目为【codeforces】题库的题目,您提交的代码将被提交至codeforces进行远程评测,并由ACGO抓取测评结果后进行展示。由于远程测评的测评机由其他平台提供,我们无法保证该服务的稳定性,若提交后无反应,请等待一段时间后再进行重试。

题目描述

给定一个长度为 nn 的排列 aa

你可以进行如下操作任意次(可以为零次):

  • 选择一个下标 ii1in21 \le i \le \frac{n}{2}),交换 aia_ia2ia_{2i}

例如,当 a=[1,4,2,3,5]a=[1,4,2,3,5] 时,你可以交换 a2a_2a4a_4 使其变为 [1,3,2,4,5][1,3,2,4,5],但你不能交换 a2a_2a3a_3

请你判断,是否可以通过若干次上述操作将序列 aa 排成升序。

一个长度为 nn 的排列是一个由 11nnnn 个互不相同的整数组成的数组。例如,[2,3,1,5,4][2,3,1,5,4] 是一个排列,但 [1,2,2][1,2,2] 不是排列(22 在数组中出现了两次),[1,3,4][1,3,4] 也不是排列(n=3n=3 但数组中有 44)。

输入格式

每组测试数据包含多个测试用例。第一行包含测试用例组数 tt1t1041 \le t \le 10^4)。接下来是各组测试用例的描述。

每个测试用例的第一行包含一个整数 nn1n21051 \le n \le 2 \cdot 10^5)。

第二行包含 nn 个不同的整数 a1,a2,,ana_1, a_2, \ldots, a_n1ain1 \le a_i \le n)。

保证所有测试用例中 nn 的总和不超过 21052 \cdot 10^5

输出格式

如果 aa 可以升序排列,则输出一行 “YES”。否则输出一行 “NO”。

输出答案时不区分大小写。例如,字符串 "yEs"、"yes" 和 "Yes" 都被视为肯定回答。

输入输出样例

  • 输入#1

    2
    5
    1 4 3 2 5
    5
    1 4 2 3 5

    输出#1

    YES
    NO

说明/提示

在第一个测试用例中,a=[1,4,3,2,5]a = [1,4,3,2,5]。你可以通过交换 a2a_2a4a_4aa 排成升序。因此答案为 “YES”。

在第二个测试用例中,a=[1,4,2,3,5]a = [1,4,2,3,5]。无论如何都无法排成升序。因此答案为 “NO”。

首页