#AGC060A. [AGC060A] No Majority

[AGC060A] No Majority

Score : 400400 points

Problem Statement

A string xx consisting of lowercase English letters is said to be good if and only if the following condition is satisfied.

  • Every (contiguous) substring of xx whose length is 22 or greater satisfies the following:- no character occupies the majority of that substring.
  • no character occupies the majority of that substring.

For example, acbca is not good because c occupies the majority of the substring cbc.

You are given a string SS of length NN consisting of lowercase English letters and ?. You want to replace each ? with a lowercase English letter of your choice to make SS a good string. Find the number of ways to make SS a good string, modulo 998244353998244353.

Constraints

  • 2N50002 \leq N \leq 5000
  • SS is a string of length NN consisting of lowercase English letters and ?.

Input

The input is given from Standard Input in the following format:

NN

SS

Output

Print the answer.

3
a?b
24

Every way other than aab and abb satisfies the condition.

3
a?a
0
20
ugsyakganihodnwmktgi
1
20
??a???h?m?y?ts???tl?
444225229