#aBC279Eid333. [ABC279E] Cheating Amidakuji

[ABC279E] Cheating Amidakuji

AT_abc279_e [ABC279E] Cheating Amidakuji

题目描述

有一个由 NN 根竖直的棍子和 MM 根连接这些棍子之间的横杆组成的“阿弥陀签”。每根横杆都垂直于竖棍,并且它们的高度各不相同。将竖棍从左到右依次编号为 1,2,,N1,2,\dots,N,横杆从上到下依次编号为 1,2,,M1,2,\dots,M。横杆 i (1iM)i\ (1\leq i\leq M) 连接了竖棍 AiA_i 和竖棍 Ai+1A_i+1 之间。

从竖棍 11 的顶端开始,沿着阿弥陀签向下走,最终到达的竖棍编号称为得分

对于 i=1,2,,Mi=1,2,\dots,M,请回答以下问题:

  • 定义 SiS_i 为将横杆 ii 删除后的得分。请计算 SiS_i

注意,实际上横杆不会真的被删除,因此每个问题是独立的。

更严格地说,具体操作如下:

给定一个长度为 MM 的数列 A=(A1,A2,,AM)A=(A_1,A_2,\dots,A_M),其中每个 AiA_i11N1N-1 之间的整数。对于 i=1,2,,Mi=1,2,\dots,M,请回答以下问题:

  • 有一个数列 B=(B1,B2,,BN)B=(B_1,B_2,\dots,B_N),初始时对于每个 jj,都有 Bj=jB_j=j。接下来,依次对 k=1,2,,i1,i+1,,Mk=1,2,\dots,i-1,i+1,\dots,M(即除了 ii 以外的 11MM 的整数 kk,按升序)进行如下操作:
    • 交换 BAkB_{A_k}BAk+1B_{A_k+1} 的值。
  • 所有操作结束后,满足 Bj=1B_j=1jj 的值即为 SiS_i。请计算 SiS_i

输入格式

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

NN MM A1A_1 A2A_2 \dots AMA_M

输出格式

输出 MM 行。对于每个 i (1iM)i\ (1\leq i\leq M),第 ii 行输出 SiS_i 的值(整数)。

输入输出样例 #1

输入 #1

5 4
1 2 3 2

输出 #1

1
3
2
4

输入输出样例 #2

输入 #2

3 3
2 2 2

输出 #2

1
1
1

输入输出样例 #3

输入 #3

10 10
1 1 1 9 4 4 2 1 3 3

输出 #3

2
2
2
3
3
3
1
3
4
4

说明/提示

限制条件

  • 2N2×1052\leq N\leq 2\times 10^5
  • 1M2×1051\leq M\leq 2\times 10^5
  • 1AiN1 (1iM)1\leq A_i\leq N-1\ (1\leq i\leq M)
  • 输入均为整数

样例解释 1

i=2i=2 时,BB 的变化如下:

  • 初始时,B=(1,2,3,4,5)B=(1,2,3,4,5)
  • k=1k=1 时,交换 B1B_1B2B_2B=(2,1,3,4,5)B=(2,1,3,4,5)
  • k=3k=3 时,交换 B3B_3B4B_4B=(2,1,4,3,5)B=(2,1,4,3,5)
  • k=4k=4 时,交换 B2B_2B3B_3B=(2,4,1,3,5)B=(2,4,1,3,5)

所有操作结束后,B3=1B_3=1,因此 S2=3S_2=3

同理:

  • i=1i=1 时:依次对 k=2,3,4k=2,3,4 操作后,B=(1,4,3,2,5)B=(1,4,3,2,5),所以 S1=1S_1=1
  • i=3i=3 时:依次对 k=1,2,4k=1,2,4 操作后,B=(2,1,3,4,5)B=(2,1,3,4,5),所以 S3=2S_3=2
  • i=4i=4 时:依次对 k=1,2,3k=1,2,3 操作后,B=(2,3,4,1,5)B=(2,3,4,1,5),所以 S4=4S_4=4

由 ChatGPT 4.1 翻译