結果
問題 |
No.2298 yukicounter
|
ユーザー |
|
提出日時 | 2023-05-13 19:28:35 |
言語 | Rust (1.83.0 + proconio) |
結果 |
WA
|
実行時間 | - |
コード長 | 2,070 bytes |
コンパイル時間 | 12,863 ms |
コンパイル使用メモリ | 378,284 KB |
実行使用メモリ | 5,248 KB |
最終ジャッジ日時 | 2024-11-29 11:10:07 |
合計ジャッジ時間 | 14,303 ms |
ジャッジサーバーID (参考情報) |
judge4 / judge1 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
sample | AC * 1 WA * 2 |
other | AC * 4 WA * 26 |
ソースコード
// 英小文字からなる文字列 S が与えられます.S に文字列 yukicoder が最大で何回連続して現れるかを求めてください. // ただし,S に文字列 yukicoder が連続して現れない場合は 0 としてください. use std::io::*; #[allow(dead_code)] // 文字列を読み込む関数 fn read_string() -> String { let mut s = String::new(); stdin().read_line(&mut s).ok(); s.trim().to_string() } #[allow(dead_code)] // 整数を読み込む関数 fn read<T: std::str::FromStr>() -> T { let s = read_string(); s.parse().ok().unwrap() } #[allow(dead_code)] // スペース区切りの整数を読み込む関数 fn read_vec<T: std::str::FromStr>() -> Vec<T> { let s = read_string(); s.split_whitespace() .map(|e| e.parse().ok().unwrap()) .collect() } #[allow(dead_code)] // 文字列を出力する関数 fn out(s: &str) { println!("{}", s); } #[allow(dead_code)] // 整数を出力する関数 fn outi<T: std::fmt::Display>(n: T) { println!("{}", n); } #[allow(dead_code)] // スペース区切りの整数を出力する関数 fn out_vec<T: std::fmt::Display>(v: Vec<T>) { let mut s = String::new(); for i in 0..v.len() { s += &v[i].to_string(); if i != v.len() - 1 { s += " "; } } println!("{}", s); } #[allow(dead_code)] // 改行区切りの整数を出力する関数 fn out_vec2<T: std::fmt::Display>(v: Vec<T>) { for i in 0..v.len() { println!("{}", v[i]); } } #[allow(dead_code)] // 2次元配列を出力する関数 fn out_vec3<T: std::fmt::Display>(v: Vec<Vec<T>>) { for i in 0..v.len() { for j in 0..v[i].len() { print!("{} ", v[i][j]); } println!(""); } } fn main() { let s = read_string(); let mut ans = 0; let mut cnt = 0; for i in 0..s.len() { if s[i..].starts_with("yukicoder") { cnt += 1; ans = std::cmp::max(ans, cnt); } else { cnt = 0; } } outi(ans); }