#aBC354F. [ABC354F] Useless for LIS

[ABC354F] Useless for LIS

AT_abc354_f [ABC354F] Useless for LIS

题目描述

给定一个长度为 NN 的整数序列 AA

对于 t=1,2,,Nt = 1, 2, \dots, N,请判断 AtA_t 是否有可能被包含在 AA 的最长严格递增子序列中。

AtA_t 有可能被包含在 AA 的最长递增子序列中,指的是存在如下情况:

  • 设最长递增子序列的长度为 LL。存在一个长度为 LL 的严格递增的整数序列 i=(i1,i2,,iL)i = (i_1, i_2, \dots, i_L),满足以下条件:
    • Ai1,Ai2,,AiLA_{i_1}, A_{i_2}, \dots, A_{i_L} 构成 AA 的一个最长严格递增子序列。
    • 存在某个 k (1kL)k\ (1 \leq k \leq L) 使得 ik=ti_k = t

给定 TT 组测试数据,请分别输出每组的答案。

最长递增子序列的定义如下:AA 的子序列是指从 AA 中取出若干元素,保持原有顺序得到的序列。AA 的最长递增子序列是指所有严格递增子序列中长度最大的那一个。

输入格式

输入按以下格式从标准输入读入。

TT
case1\mathrm{case}_1
case2\mathrm{case}_2
\vdots
caseT\mathrm{case}_T

其中 casei\mathrm{case}_i 表示第 ii 组测试数据,格式如下:

NN A1A_1 A2A_2 \cdots ANA_N

输出格式

请按以下格式输出。

answer1\mathrm{answer}_1
answer2\mathrm{answer}_2
\vdots
answerT\mathrm{answer}_T

其中 answeri\mathrm{answer}_i 表示第 ii 组测试数据的输出。对于每组数据,假设有 mmtt 满足 AtA_t 可以被包含在 AA 的最长递增子序列中,且这些 tt 升序排列为 i1,i2,,imi_1, i_2, \dots, i_m,则输出格式如下:

mm i1i_1 i2i_2 \cdots imi_m

输入输出样例 #1

输入 #1

1
5
2 1 4 5 3

输出 #1

4
1 2 3 4

输入输出样例 #2

输入 #2

2
6
2 5 3 4 3 4
5
10000 1000 100 1 10

输出 #2

5
1 3 4 5 6
2
4 5

说明/提示

数据范围

  • 1T2×1051 \leq T \leq 2 \times 10^5
  • 1N2×1051 \leq N \leq 2 \times 10^5
  • 1Ai1091 \leq A_i \leq 10^9
  • 所有测试数据中 NN 的总和不超过 2×1052 \times 10^5

样例解释 1

最长递增子序列之一为 (2,4,5)(2, 4, 5),长度为 33(1,4,5)(1, 4, 5) 也是最长递增子序列之一。但是,没有包含 A5A_5 的最长递增子序列。因此,应输出 1,2,3,41, 2, 3, 4

由 ChatGPT 4.1 翻译