#CF2195B. Heapify 1

    ID: 7027 传统题 1000ms 256MiB 尝试: 1 已通过: 1 难度: 10 上传者: 标签>模拟排序CodeforcesCodeforces Round 1080(Div3)Div3BCF2195B900

Heapify 1

题目描述

给定一个长度为 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" 都被视为肯定回答。

样例

2
5
1 4 3 2 5
5
1 4 2 3 5
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”。

由 ChatGPT 5 翻译

来源

Codeforces 2195B,英文题名 Heapify 1。