結果
| 問題 |
No.358 も~っと!門松列
|
| コンテスト | |
| ユーザー |
tubo28
|
| 提出日時 | 2016-04-17 22:51:03 |
| 言語 | Rust (1.83.0 + proconio) |
| 結果 |
CE
(最新)
AC
(最初)
|
| 実行時間 | - |
| コード長 | 1,959 bytes |
| コンパイル時間 | 12,117 ms |
| コンパイル使用メモリ | 390,120 KB |
| 最終ジャッジ日時 | 2024-11-14 19:42:11 |
| 合計ジャッジ時間 | 12,953 ms |
|
ジャッジサーバーID (参考情報) |
judge5 / judge3 |
(要ログイン)
コンパイルエラー時のメッセージ・ソースコードは、提出者また管理者しか表示できないようにしております。(リジャッジ後のコンパイルエラーは公開されます)
ただし、clay言語の場合は開発者のデバッグのため、公開されます。
ただし、clay言語の場合は開発者のデバッグのため、公開されます。
コンパイルメッセージ
error: use of deprecated `try` macro --> src/main.rs:44:17 | 44 | 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 | 44 - let s = try!(self.fetch_token()); 44 + let s = self.fetch_token()?; | help: alternatively, you can still access the deprecated `try!()` macro using the "raw identifier" syntax | 44 | let s = r#try!(self.fetch_token()); | ++ error: use of deprecated `try` macro --> src/main.rs:45:17 | 45 | 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 | 45 - let t = try!(s.parse::<T>().map_err(|_| "Parse error")); 45 + let t = s.parse::<T>().map_err(|_| "Parse error")?; | help: alternatively, you can still access the deprecated `try!()` macro using the "raw identifier" syntax | 45 | let t = r#try!(s.parse::<T>().map_err(|_| "Parse error")); | ++ error: could not compile `main` (bin "main") due to 2 previous errors
ソースコード
fn main(){
let mut sc = Scanner::new();
while let Ok(a) = sc.wrapped() {
let b = sc.next();
let c = sc.next();
let ans = if is_kdmt(a,b,c,100000000000) {
String::from("INF")
} else {
let mut cnt = 0;
for p in 1..100000 {
if is_kdmt(a,b,c,p) {
cnt += 1;
}
}
cnt.to_string()
};
println!("{}", ans);
}
}
fn is_kdmt(x: i64, y: i64, z: i64, p: i64) -> bool {
let x = x % p;
let y = y % p;
let z = z % p;
return x != y && y != z && z != x &&
((y < x && y < z) || (y > x && y > z));
}
// Scanner
#[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 ni(& mut self) -> i32 {
self.next::<i32>()
}
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])
}
}
tubo28