#include using namespace std; #include using namespace atcoder; using mint = modint998244353; int main () { string s, t; cin >> s >> t; int N = s.size(), M = t.size(); std::vector dp(M + 1, 0); dp[0] = 1; for (int i = 0; i < N; i ++) { for (int j = M - 1; j >= 0; j --) { if (s[i] == t[j]) { dp[j + 1] += dp[j]; } } } mint bi = 1; for (int i = 0; i < N - M; i ++) { bi *= 2; } cout << (dp[M] * bi).val() << endl; }