- 题解
Day07 - T6
- @ 2026-2-10 21:06:53
#include <bits/stdc++.h>
using namespace std;
const int N = 5e5 + 10, mod = 998244353;
int f[N][2][2];
int main() {
int t = 1;
// cin >> t;
while (t--) {
string s;
cin >> s;
memset(f, 0, sizeof f);
if (s[0] == '0') {
f[0][0][0] = 1;
}
if (s[0] == '1') {
f[0][1][0] = 1;
}
if (s[0] == '?') {
f[0][0][0] = 1;
f[0][1][0] = 1;
}
for (int i = 1; i < s.size(); i++) {
if (s[i] == '0') {
f[i][0][0] = (f[i - 1][0][1] + f[i - 1][1][0]) % mod;
f[i][0][1] = (f[i - 1][0][0] + f[i - 1][1][1]) % mod;
}
if (s[i] == '1') {
f[i][1][0] = (f[i - 1][0][0] + f[i - 1][1][1]) % mod;
f[i][1][1] = (f[i - 1][0][1] + f[i - 1][1][0]) % mod;
}
if (s[i] == '?') {
f[i][0][0] = (f[i - 1][0][1] + f[i - 1][1][0]) % mod;
f[i][0][1] = (f[i - 1][0][0] + f[i - 1][1][1]) % mod;
f[i][1][0] = (f[i - 1][0][0] + f[i - 1][1][1]) % mod;
f[i][1][1] = (f[i - 1][0][1] + f[i - 1][1][0]) % mod;
}
}
cout << (f[s.size() - 1][1][0] + f[s.size() - 1][0][0]) % mod << '\n';
}
return 0;
}
0 条评论
目前还没有评论...