For problem statement at 1000-1999/1100-1199/1140-1149/1140/problemE.txt this is a correct solution, but verifier at 1000-1999/1100-1199/1140-1149/1140/verifierE.go ends with All tests passed can you fix the verifier? ```go
package main
import (
"bufio"
"fmt"
"os"
"strconv"
)
func power(base, exp int64) int64 {
res := int64(1)
base %= 998244353
for exp > 0 {
if exp%2 == 1 {
res = (res * base) % 998244353
}
base = (base * base) % 998244353
exp /= 2
}
return res
}
func solve1D(b []int, k int, A []int64, B []int64) int64 {
m := len(b)
if m == 0 {
return 1
}
first := -1
last := -1
for i := 0; i < m; i++ {
if b[i] != -1 {
if first == -1 {
first = i
}
last = i
}
}
if first == -1 {
ans := int64(k) % 998244353
kMinus1 := (int64(k) - 1 + 998244353) % 998244353
ans = (ans * power(kMinus1, int64(m-1))) % 998244353
return ans
}
ans := int64(1)
kMinus1 := (int64(k) - 1 + 998244353) % 998244353
ans = (ans * power(kMinus1, int64(first))) % 998244353
ans = (ans * power(kMinus1, int64(m-1-last))) % 998244353
prev := first
for i := first + 1; i <= last; i++ {
if b[i] != -1 {
gap := i - prev - 1
if b[prev] == b[i] {
ans = (ans * A[gap+2]) % 998244353
} else {
ans = (ans * B[gap+2]) % 998244353
}
prev = i
}
}
return ans
}
func main() {
scanner := bufio.NewScanner(os.Stdin)
scanner.Split(bufio.ScanWords)
buf := make([]byte, 1024*1024*10)
scanner.Buffer(buf, 1024*1024*10)
if !scanner.Scan() {
return
}
n, _ := strconv.Atoi(scanner.Text())
if !scanner.Scan() {
return
}
k, _ := strconv.Atoi(scanner.Text())
a := make([]int, n)
for i := 0; i < n; i++ {
scanner.Scan()
a[i], _ = strconv.Atoi(scanner.Text())
}
A := make([]int64, n+3)
B := make([]int64, n+3)
A[1] = 1
B[1] = 0
kMinus2 := (int64(k) - 2 + 998244353) % 998244353
kMinus1 := (int64(k) - 1 + 998244353) % 998244353
for i := 2; i <= n+2; i++ {
A[i] = (kMinus1 * B[i-1]) % 998244353
B[i] = (A[i-1] + kMinus2*B[i-1]) % 998244353
}
AOdd := make([]int, 0, (n+1)/2)
AEven := make([]int, 0, n/2)
for i := 0; i < n; i++ {
if i%2 == 0 {
AOdd = append(AOdd, a[i])
} else {
AEven = append(AEven, a[i])
}
}
ans1 := solve1D(AOdd, k, A, B)
ans2 := solve1D(AEven, k, A, B)
finalAns := (ans1 * ans2) % 998244353
fmt.Println(finalAns)
}
```