結果
問題 | No.2219 Re:010 |
ユーザー |
|
提出日時 | 2023-02-17 22:00:38 |
言語 | Rust (1.83.0 + proconio) |
結果 |
AC
|
実行時間 | 6 ms / 2,000 ms |
コード長 | 802 bytes |
コンパイル時間 | 13,286 ms |
コンパイル使用メモリ | 380,024 KB |
実行使用メモリ | 5,376 KB |
最終ジャッジ日時 | 2024-07-19 13:13:09 |
合計ジャッジ時間 | 12,735 ms |
ジャッジサーバーID (参考情報) |
judge5 / judge3 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
sample | AC * 3 |
other | AC * 21 |
ソースコード
fn getline() -> String { let mut ret = String::new(); std::io::stdin().read_line(&mut ret).ok().unwrap(); ret } const MOD: i64 = 998_244_353; fn main() { let s: Vec<_> = getline().trim().bytes().collect(); let n = s.len(); let mut dp = [0; 4]; let t = b"101"; dp[0] = 1; for i in 0..n { let mut ep = dp; if s[i] == b'?' { for j in 0..4 { ep[j] *= 2; if ep[j] >= MOD { ep[j] -= MOD; } } } for j in 0..3 { if s[i] != t[j] { ep[j + 1] += dp[j]; if ep[j + 1] >= MOD { ep[j + 1] -= MOD; } } } dp = ep; } println!("{}", dp[3]); }