#L2241. 「CQOI2014」排序机械臂

「CQOI2014」排序机械臂

题目描述

SORT 公司是一个专门为人们提供排序服务的公司,该公司的宗旨是「顺序是最美丽的」。

为了把工厂中高低不等的物品按从低到高排好序,工程师发明了一种排序机械臂。

它遵循一个简单的排序规则:

  • ii 次操作找到高度第 ii 低的物品的位置 PiP_i,并把左起第 ii 个物品至 PiP_i 间的物品(即区间 [i,Pi][i, P_i] 间的物品)反序;
  • 最终所有的物品都会被排好序。

上图给出有六个物品的示例,第一次操作前,高度最低的物品在位置 44,于是把第一至第四的物品反序;第二次操作前,第二低的物品在位置 66,于是把第二至第六的物品反序……

你的任务便是编写一个程序,确定一个操作序列,即每次操作前第 ii 低的物品所在位置 PiP_i,以便机械臂工作。
注意:如果有高度相同的物品,必须保证排序后它们的相对位置关系与初始时相同。


输入格式
输入共两行:

  • 第一行为一个整数 NN,表示物品的个数。
  • 第二行为 NN 个用空格隔开的正整数,表示 NN 个物品最初排列的编号。

输出格式
输出共一行,NN 个用空格隔开的正整数 P1,P2,P3,,PnP_1, P_2, P_3, \ldots, P_nPiP_i 表示第 ii 次操作前第 ii 小的物品所在的位置。

注意:如果第 ii 次操作前,第 ii 小的物品已经在正确的位置 PiP_i 上,我们将区间 [Pi,Pi][P_i, P_i] 反转(单个物品)。


样例
输入

6
3 4 5 1 6 2

输出

4 6 4 5 6 6

数据范围与提示
对于所有的数据,1N1000001 \leq N \leq 100000