Preparando MOJI

Vasya and Array

2000ms 524288K

Description:

Vasya has got an array consisting of $$$n$$$ integers, and two integers $$$k$$$ and $$$len$$$ in addition. All numbers in the array are either between $$$1$$$ and $$$k$$$ (inclusive), or equal to $$$-1$$$. The array is good if there is no segment of $$$len$$$ consecutive equal numbers.

Vasya will replace each $$$-1$$$ with some number from $$$1$$$ to $$$k$$$ (inclusive) in such a way that the resulting array is good. Tell him the number of ways to do this replacement. Since the answer may be large, print it modulo $$$998244353$$$.

Input:

The first line contains three integers $$$n, k$$$ and $$$len$$$ ($$$1 \le n \le 10^5, 1 \le k \le 100, 1 \le len \le n$$$).

The second line contains $$$n$$$ numbers — the array. Each number is either $$$-1$$$ or between $$$1$$$ and $$$k$$$ (inclusive).

Output:

Print one integer — the number of ways to replace each $$$-1$$$ with some number from $$$1$$$ to $$$k$$$ (inclusive) so the array is good. The answer may be large, so print it modulo $$$998244353$$$.

Sample Input:

5 2 3
1 -1 1 -1 2

Sample Output:

2

Sample Input:

6 3 2
1 1 -1 -1 -1 -1

Sample Output:

0

Sample Input:

10 42 7
-1 -1 -1 -1 -1 -1 -1 -1 -1 -1

Sample Output:

645711643

Note:

Possible answers in the first test:

  1. $$$[1, 2, 1, 1, 2]$$$;
  2. $$$[1, 2, 1, 2, 2]$$$.

There is no way to make the array good in the second test, since first two elements are equal.

There are too many answers in the third test, so we won't describe any of them.

Informação

Codeforces

Provedor Codeforces

Código CF1093F

Tags

dp

Submetido 0

BOUA! 0

Taxa de BOUA's 0%

Datas 09/05/2023 09:43:23

Relacionados

Nada ainda