#ATagc014f. [AGC014F] Strange Sorting

[AGC014F] Strange Sorting

题目描述

高桥君非常喜欢排序。

因此,他准备了一个从 11NN 的排列 (p1,p2,,pN)(p_1, p_2, \ldots, p_N),并且他打算反复进行以下操作,直到该排列变成 (1,2,,N)(1,2,\ldots,N) 为止:

  • 首先,对于排列中的每一项 ii,如果从第 11 项到第 ii 项的最大值等于第 ii 项本身,则称这一项为「高项」,否则称为「低项」。
  • 然后,按照当前排列的顺序,将高项中的数记为 a1,a2,,aka_1, a_2, \ldots, a_k,低项中的数记为 b1,b2,,bNkb_1, b_2, \ldots, b_{N-k}
  • 最后,将排列重新排列为 (b1,b2,,bNk,a1,a2,,ak)(b_1, b_2, \ldots, b_{N-k}, a_1, a_2, \ldots, a_k)

请你求出高桥君完成排序所需的操作次数。

输入格式

输入包含一行:

NN p1p_1 p2p_2 ... pNp_N

输出格式

输出高桥君完成排序所需的操作次数。

样例 1

输入

5
3 5 1 2 4

输出

3

样例 2

输入

5
5 4 3 2 1

输出

4

样例 3

输入

10
2 10 5 7 3 6 4 9 8 1

输出

6

说明/提示

限制条件

  • 1N2×1051\leq N\leq 2\times 10^5
  • (p1,p2,,pN)(p_1,p_2,\ldots,p_N)11NN 的一个排列。

样例说明 1

高桥君最开始有排列 (3,5,1,2,4)(3,5,1,2,4),每次操作后,排列如下所示:

  • 1122 项是高项,第 334455 项是低项,所以下一个排列是 (1,2,4,3,5)(1,2,4,3,5)
  • 11223355 项是高项,第 44 项是低项,所以下一个排列是 (3,1,2,4,5)(3,1,2,4,5)
  • 114455 项是高项,第 2233 项是低项,所以下一个排列是 (1,2,3,4,5)(1,2,3,4,5)

由 ChatGPT 5 翻译