#aBC347E. [ABC347E] Set Add Query

[ABC347E] Set Add Query

AT_abc347_e [ABC347E] Set Add Query

题目描述

有一个长度为 NN 的整数序列 A=(A1,A2,,AN)A=(A_1,A_2,\ldots,A_N),所有元素初始为 00。同时有一个集合 SS,初始为空。

你需要依次处理以下 QQ 个查询。请在处理完所有 QQ 个查询后,输出序列 AA 的每个元素的值。第 ii 个查询如下:

  • 给定一个整数 xix_i。如果 xix_i 已经在集合 SS 中,则将 xix_iSS 中删除;否则,将 xix_i 加入 SS。接下来,对于所有 j=1,2,,Nj=1,2,\ldots,N,如果 jSj\in S,则将 S|S| 加到 AjA_j 上。

其中,S|S| 表示集合 SS 的元素个数。例如,当 S={3,4,7}S=\lbrace 3,4,7\rbrace 时,S=3|S|=3

输入格式

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

NN QQ x1x_1 x2x_2 \ldots xQx_Q

输出格式

请输出处理完所有查询后的序列 AA,格式如下:

A1A_1 A2A_2 \ldots ANA_N

输入输出样例 #1

输入 #1

3 4
1 3 3 2

输出 #1

6 2 2

输入输出样例 #2

输入 #2

4 6
1 2 3 2 4 2

输出 #2

15 9 12 7

说明/提示

限制条件

  • 1N,Q2×1051\leq N,Q\leq 2\times 10^5
  • 1xiN1\leq x_i\leq N
  • 输入的所有数均为整数

样例解释 1

11 个查询,将 11 加入 SS,此时 S={1}S=\lbrace 1\rbrace。然后,A1A_1 加上 S=1|S|=1A=(1,0,0)A=(1,0,0)

22 个查询,将 33 加入 SS,此时 S={1,3}S=\lbrace 1,3\rbrace。然后,A1,A3A_1,A_3 各加上 S=2|S|=2A=(3,0,2)A=(3,0,2)

33 个查询,将 33SS 中删除,S={1}S=\lbrace 1\rbrace。然后,A1A_1 加上 S=1|S|=1A=(4,0,2)A=(4,0,2)

44 个查询,将 22 加入 SSS={1,2}S=\lbrace 1,2\rbrace。然后,A1,A2A_1,A_2 各加上 S=2|S|=2A=(6,2,2)A=(6,2,2)

最终,A=(6,2,2)A=(6,2,2)

由 ChatGPT 4.1 翻译