#aBC247EX. [ABC247Ex] Rearranging Problem

[ABC247Ex] Rearranging Problem

AT_abc247_h [ABC247Ex] Rearranging Problem

题目描述

NN 个人,编号为 1,2,,N1, 2, \dots, N,他们按照 (1,2,,N)(1,2,\dots,N) 的顺序排成一列。第 ii 个人穿着颜色为 cic_i 的衣服。
高桥君进行了 KK 次操作,每次操作可以任选两个人 i,ji, j,交换他们的位置。
KK 次操作结束后,对于所有满足 1iN1 \leq i \leq N 的整数 ii,从前往后第 ii 个人所穿的衣服颜色都与 cic_i 一致。
请问在 KK 次操作结束后,可能出现多少种不同的人的排列方式?请将答案对 998244353998244353 取模后输出。

输入格式

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

NN KK c1c_1 c2c_2 \dots cNc_N

输出格式

请输出答案。

输入输出样例 #1

输入 #1

4 1
1 1 2 1

输出 #1

3

输入输出样例 #2

输入 #2

3 3
1 1 2

输出 #2

1

输入输出样例 #3

输入 #3

10 4
2 7 1 8 2 8 1 8 2 8

输出 #3

132

说明/提示

限制条件

  • 2N2000002 \leq N \leq 200000
  • 1K1091 \leq K \leq 10^9
  • 1ciN1 \leq c_i \leq N
  • 输入的所有数均为整数。

样例解释 1

高桥君的操作以及操作后可能的排列如下所示。

  • 将第 11 个人和第 22 个人交换位置。操作后排列为 (2,1,3,4)(2, 1, 3, 4)
  • 将第 11 个人和第 44 个人交换位置。操作后排列为 (4,2,3,1)(4, 2, 3, 1)
  • 将第 22 个人和第 44 个人交换位置。操作后排列为 (1,4,3,2)(1, 4, 3, 2)

样例解释 2

举一个可能的高桥君的操作例子如下。

  • 11 次操作,将第 11 个人和第 33 个人交换位置。操作后排列为 (3,2,1)(3, 2, 1)
  • 22 次操作,将第 22 个人和第 33 个人交换位置。操作后排列为 (2,3,1)(2, 3, 1)
  • 33 次操作,将第 11 个人和第 33 个人交换位置。操作后排列为 (2,1,3)(2, 1, 3)。 请注意,在操作过程中,从前往后第 ii 个人的衣服颜色不一定始终与 cic_i 一致。

由 ChatGPT 4.1 翻译