from collections import deque N,M=map(int,input().split()) S=input() C="aoi" Qcnt=S.count("?") Q=[] for i in range(N): if S[i]=="a" or S[i]=="?":Q.append(((i,),[S[i]])) G=[[] for _ in range(N)] for _ in range(M): A,B=map(int,input().split()) A-=1;B-=1 G[A].append(B) G[B].append(A) Q=deque(Q) ans=0 while Q: path,str=Q.popleft() for nxt in G[path[-1]]: if nxt in path:continue if S[nxt]==C[len(path)] or S[nxt]=="?": if len(path)==2: str.append(S[nxt]) ans+=26**(Qcnt-str.count("?")) else:Q.append((path+(nxt,),str+[S[nxt]])) print(ans%998244353)