#ATarc080c. [ARC080E] Young Maids

[ARC080E] Young Maids

题目描述

NN 为一个正的偶数。

有一个排列 p=(p1,p2,...,pN)p = (p_1, p_2, ..., p_N),其为 11NN 的一个排列。すぬけ君希望通过如下过程构造出一个 11NN 的排列 qq

首先,准备一个空序列 qq。然后重复以下操作,直到 pp 变为空:

  • 选择 pp 中相邻的两个元素,依次记为 xxyy,将 xxyypp 中移除(此时 pp 长度减少 22),再将 xxyy 按顺序插入到 qq 的开头。

pp 为空时,qq 就是一个 11NN 的排列。

请你输出字典序最小的 qq

输入格式

输入从标准输入中以如下格式给出:

N p1 p2 ... pNN\ p_1\ p_2\ ...\ p_N

输出格式

请输出字典序最小的 qq,各元素用空格分隔。

样例 1

输入

4
3 2 4 1

输出

3 1 2 4

样例 2

输入

2
1 2

输出

1 2

样例 3

输入

8
4 6 3 2 8 5 7 1

输出

3 1 2 7 4 6 8 5

说明/提示

限制条件

  • NN 是偶数。
  • 2N2×1052 \leq N \leq 2 \times 10^5
  • pp11NN 的一个排列。

样例说明 1

按照如下顺序操作即可:

p     qp\ \ \ \ \ q

(3,2,4,1)    ()(3, 2, 4, 1)\ \ \ \ ()

  \downarrow\ \ \downarrow

(3,1)   (2,4)(3, 1)\ \ \ (2, 4)

  \downarrow\ \ \downarrow

()   (3,1,2,4)()\ \ \ (3, 1, 2, 4)

样例说明 3

可以按照如下操作完成:

p     qp\ \ \ \ \ q

(4,6,3,2,8,5,7,1)    ()(4, 6, 3, 2, 8, 5, 7, 1)\ \ \ \ ()

  \downarrow\ \ \downarrow

(4,6,3,2,7,1)   (8,5)(4, 6, 3, 2, 7, 1)\ \ \ (8, 5)

  \downarrow\ \ \downarrow

(3,2,7,1)   (4,6,8,5)(3, 2, 7, 1)\ \ \ (4, 6, 8, 5)

  \downarrow\ \ \downarrow

(3,1)   (2,7,4,6,8,5)(3, 1)\ \ \ (2, 7, 4, 6, 8, 5)

  \downarrow\ \ \downarrow

()   (3,1,2,7,4,6,8,5)()\ \ \ (3, 1, 2, 7, 4, 6, 8, 5)

由 ChatGPT 5 翻译