#P1093F. Vasya and Array

Vasya and Array

Description

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

Vasya will replace each 1-1 with some number from 11 to kk (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 998244353998244353.

The first line contains three integers n,kn, k and lenlen (1n105,1k100,1lenn1 \le n \le 10^5, 1 \le k \le 100, 1 \le len \le n).

The second line contains nn numbers — the array. Each number is either 1-1 or between 11 and kk (inclusive).

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

Input

The first line contains three integers n,kn, k and lenlen (1n105,1k100,1lenn1 \le n \le 10^5, 1 \le k \le 100, 1 \le len \le n).

The second line contains nn numbers — the array. Each number is either 1-1 or between 11 and kk (inclusive).

Output

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

Sample Input 1

5 2 3
1 -1 1 -1 2

Sample Output 1

2

Sample Input 2

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

Sample Output 2

0

Sample Input 3

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

Sample Output 3

645711643

Note

Possible answers in the first test:

  1. [1,2,1,1,2][1, 2, 1, 1, 2];
  2. [1,2,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.