#aBC306C. [ABC306C] Centers

[ABC306C] Centers

AT_abc306_c [ABC306C] Centers

题目描述

给定一个长度为 3N3N 的数列 A=(A1,A2,,A3N)A=(A_1,A_2,\dots,A_{3N}),其中 1,2,,N1,2,\dots,N 每个数字恰好出现 33 次。

对于 i=1,2,,Ni=1,2,\dots,N,定义 f(i)f(i)AA 中数字 ii 出现的三个位置中间的那个位置的下标。请将 1,2,,N1,2,\dots,N 按照 f(i)f(i) 的升序重新排列并输出。

f(i)f(i) 的严格定义如下:

  • Aj=iA_j = i 的所有 jjj=α,β,γj = \alpha, \beta, \gamma,且 α<β<γ\alpha < \beta < \gamma,则 f(i)=βf(i) = \beta

输入格式

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

NN A1A_1 A2A_2 \dots A3NA_{3N}

输出格式

请输出将 1,2,,N1,2,\dots,N 按照 f(i)f(i) 的升序排列后得到的长度为 NN 的数列,数之间用空格隔开。

输入输出样例 #1

输入 #1

3
1 1 3 2 3 2 2 3 1

输出 #1

1 3 2

输入输出样例 #2

输入 #2

1
1 1 1

输出 #2

1

输入输出样例 #3

输入 #3

4
2 3 4 3 4 1 3 1 1 4 2 2

输出 #3

3 4 1 2

说明/提示

限制条件

  • 1N1051 \leq N \leq 10^5
  • 1AjN1 \leq A_j \leq N
  • 对于每个 i=1,2,,Ni=1,2,\dots,NAA 中的 ii 恰好出现 33
  • 所有输入均为整数

样例解释 1

  • AA11 出现在 A1,A2,A9A_1,A_2,A_9,因此 f(1)=2f(1)=2
  • AA22 出现在 A4,A6,A7A_4,A_6,A_7,因此 f(2)=6f(2)=6
  • AA33 出现在 A3,A5,A8A_3,A_5,A_8,因此 f(3)=5f(3)=5。 因此,f(1)<f(3)<f(2)f(1)<f(3)<f(2),所以输出顺序为 1,3,21,3,2

由 ChatGPT 4.1 翻译