#aBC293B. [ABC293B] Call the ID Number

[ABC293B] Call the ID Number

AT_abc293_b [ABC293B] Call the ID Number

题目描述

NN 个人,编号为 1122\ldotsNN

NN 个人会按照人 11、人 22\ldots、人 NN 的顺序,各自恰好进行一次如下操作:

  • 如果第 ii 个人还没有被别人叫过编号,那么他会叫出人 AiA_i 的编号。

请将最后一次都没有被别人叫过编号的所有人的编号按升序输出。

输入格式

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

NN A1A_1 A2A_2 \ldots ANA_N

输出格式

请按如下格式输出最后一次都没有被别人叫过编号的所有人的编号。

KK
X1X_1 X2X_2 \ldots XKX_K

即,第一行输出最后一次都没有被别人叫过编号的人的人数 KK,第二行输出这些人的编号,按升序排列,编号之间用空格隔开。

输入输出样例 #1

输入 #1

5
3 1 4 5 4

输出 #1

2
2 4

输入输出样例 #2

输入 #2

20
9 7 19 7 10 4 13 9 4 8 10 15 16 3 18 19 12 13 2 12

输出 #2

10
1 2 5 6 8 11 14 17 18 20

说明/提示

限制条件

  • 2N2×1052 \leq N \leq 2 \times 10^5
  • 1AiN1 \leq A_i \leq N
  • AiiA_i \neq i
  • 输入均为整数

样例解释 1

55 个人的操作如下:

  • 11 还没有被叫过编号,所以人 11 叫了人 33 的编号。
  • 22 还没有被叫过编号,所以人 22 叫了人 11 的编号。
  • 33 已经被人 11 叫过编号,所以什么都不做。
  • 44 还没有被叫过编号,所以人 44 叫了人 55 的编号。
  • 55 已经被人 44 叫过编号,所以什么都不做。

因此,最后一次都没有被别人叫过编号的是人 22 和人 44

由 ChatGPT 4.1 翻译