S, T = input().split() # dp[i][j] := Sのi文字目まで見て、Tのj文字目まで一致しているようなものの個数 dp = [[0]*(len(T)+1) for _ in range(2)] dp[0][0] = 1 mod = 998244353 for i in range(len(S)): dp[(i+1)&1] = [0] * (len(T)+1) for j in range(len(T)+1): dp[(i+1)&1][j] += dp[i&1][j] dp[(i+1)&1][j] %= mod if j < len(T) and S[i] == T[j]: dp[(i+1)&1][j+1] += dp[i&1][j] dp[(i+1)&1][j+1] %= mod print(dp[len(S)&1][len(T)] * (1<