loj#P4034. 「CCO 2023」Line Town

「CCO 2023」Line Town

题目描述

译自 CCO 2023 Day1 T3「Line Town

线条小镇的 NN 个居民排成了一条线。最初,居民们从左到右沿着线的幸福值为 h1,h2,,hNh_{1}, h_{2}, \ldots, h_{N}

你是线条小镇的镇长,你正在实施你的名为「社区、糖果和组织」(CCO)的计划。因此,你拥有了交换居民位置的权力。在一次交换中,你可以让两个相邻的居民交换他们在线中的位置。但是,这次交换会导致两个居民的幸福值取反。

你想要知道是否能进行一些交换,使得居民的幸福值从左到右按非递减的顺序排列。如果可能,需要的最少交换次数是多少。

输入格式

第一行包含一个整数 NN

第二行包含 NN 个整数 h1,,hNh_{1}, \ldots, h_{N},表示从左到右的居民的幸福值。

输出格式

输出一行一个整数,表示最少的交换次数,如果任务不可能完成输出 1-1

6
-2 7 -1 -8 2 8
3

可以进行 33 次交换,如下所示:

  1. 交换第 22 和第 33 个居民,幸福值变成了 [2,1,7,8,2,8][-2,1,-7,-8,2,8]
  2. 交换第 44 和第 55 个居民,幸福值变成了 [2,1,7,2,8,8][-2,1,-7,-2,8,8]
  3. 交换第 33 和第 44 个居民,幸福值变成了 [2,1,2,7,8,8][-2,1,2,7,8,8]

居民们现在按照要求的幸福值非递减的顺序排列了。没有比 33 次更少的交换次数可以得到非递减的排列。

4
1 -1 1 -1
-1

没有一系列的交换可以使居民按照幸福值非递减的顺序排列。

数据范围与提示

对于所有的数据,有 1N5×1051\leq N\leq 5\times 10^5109hi109-10^{9} \leq h_{i} \leq 10^{9}

子任务编号 分值 NN 的范围 额外限制
11 1212 1N20001 \leq N \leq 2000 对于所有的 iihi=1\left|h_{i}\right|=1
22 1212 1N5×1051 \leq N \leq 5\times 10^5
33 1212 1N20001 \leq N \leq 2000 对于所有的 iihi1\left|h_{i}\right| \leq 1
44 1616 1N5×1051 \leq N \leq 5\times 10^5
55 1616 1N20001 \leq N \leq 2000 对于所有的 iji \neq jhihj\left|h_{i}\right| \neq\left|h_{j}\right|
66 1212 1N5×1051 \leq N \leq 5\times 10^5
77 88 1N20001 \leq N \leq 2000 没有额外的限制
88 1212 1N5×1051 \leq N \leq 5\times 10^5