結果
問題 | No.279 木の数え上げ |
ユーザー | tubo28 |
提出日時 | 2016-04-04 14:45:56 |
言語 | Rust (1.77.0 + proconio) |
結果 |
CE
(最新)
AC
(最初)
|
実行時間 | - |
コード長 | 1,779 bytes |
コンパイル時間 | 12,127 ms |
コンパイル使用メモリ | 384,252 KB |
最終ジャッジ日時 | 2024-11-14 19:40:55 |
合計ジャッジ時間 | 12,906 ms |
ジャッジサーバーID (参考情報) |
judge2 / judge3 |
(要ログイン)
コンパイルエラー時のメッセージ・ソースコードは、提出者また管理者しか表示できないようにしております。(リジャッジ後のコンパイルエラーは公開されます)
ただし、clay言語の場合は開発者のデバッグのため、公開されます。
ただし、clay言語の場合は開発者のデバッグのため、公開されます。
コンパイルメッセージ
error: use of deprecated `try` macro --> src/main.rs:36:17 | 36 | let s = try!(self.fetch_token()); | ^^^^^^^^^^^^^^^^^^^^^^^^ | = note: in the 2018 edition `try` is a reserved keyword, and the `try!()` macro is deprecated help: you can use the `?` operator instead | 36 - let s = try!(self.fetch_token()); 36 + let s = self.fetch_token()?; | help: alternatively, you can still access the deprecated `try!()` macro using the "raw identifier" syntax | 36 | let s = r#try!(self.fetch_token()); | ++ error: use of deprecated `try` macro --> src/main.rs:37:17 | 37 | let t = try!(s.parse::<T>().map_err(|_| "Parse error")); | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ | = note: in the 2018 edition `try` is a reserved keyword, and the `try!()` macro is deprecated help: you can use the `?` operator instead | 37 - let t = try!(s.parse::<T>().map_err(|_| "Parse error")); 37 + let t = s.parse::<T>().map_err(|_| "Parse error")?; | help: alternatively, you can still access the deprecated `try!()` macro using the "raw identifier" syntax | 37 | let t = r#try!(s.parse::<T>().map_err(|_| "Parse error")); | ++ error: could not compile `main` (bin "main") due to 2 previous errors
ソースコード
use std::collections::HashMap; fn main(){ let mut sc = Scanner::new(); while let Ok(s) = sc.wrapped::<String>() { let mut h:HashMap<char,i32> = HashMap::new(); h.insert('t', 0); h.insert('r', 0); h.insert('e', 0); for c in s.chars() { match h.get(&c).cloned() { Some(k) => { h.insert(c, k+1); }, None => { h.insert(c, 1); }, } }; let x = std::cmp::min(h[&'t'], h[&'r']); let x = std::cmp::min(x, h[&'e']/2); println!("{}",x); } } #[allow(dead_code)] struct Scanner { token_buffer : Vec<String>, index : usize, } #[allow(dead_code)] impl Scanner { fn new() -> Scanner { Scanner { token_buffer: vec![], index: 0 } } fn wrapped<T>(&mut self) -> Result<T,&str> where T: std::str::FromStr { let s = try!(self.fetch_token()); let t = try!(s.parse::<T>().map_err(|_| "Parse error")); Ok(t) } fn next<T>(&mut self) -> T where T: std::str::FromStr { self.wrapped::<T>().unwrap() } fn fetch_token(&mut self) -> Result<&String,&str> { while self.index >= self.token_buffer.len() { let mut st = String::new(); while st.trim() == "" { match std::io::stdin().read_line(&mut st) { Ok(l) if l > 0 => continue, Ok(_) => return Err("End of file"), Err(_) => return Err("Failed to read line"), } } self.token_buffer = st.split_whitespace() .map(|x| x.to_string()) .collect(); self.index = 0; } self.index += 1; Ok(&self.token_buffer[self.index - 1]) } }