結果
| 問題 |
No.1556 Power Equality
|
| コンテスト | |
| ユーザー |
Strorkis
|
| 提出日時 | 2021-06-25 21:34:32 |
| 言語 | Rust (1.83.0 + proconio) |
| 結果 |
CE
(最新)
AC
(最初)
|
| 実行時間 | - |
| コード長 | 2,342 bytes |
| コンパイル時間 | 12,334 ms |
| コンパイル使用メモリ | 388,888 KB |
| 最終ジャッジ日時 | 2024-11-15 01:29:14 |
| 合計ジャッジ時間 | 13,008 ms |
|
ジャッジサーバーID (参考情報) |
judge5 / judge4 |
(要ログイン)
コンパイルエラー時のメッセージ・ソースコードは、提出者また管理者しか表示できないようにしております。(リジャッジ後のコンパイルエラーは公開されます)
ただし、clay言語の場合は開発者のデバッグのため、公開されます。
ただし、clay言語の場合は開発者のデバッグのため、公開されます。
コンパイルメッセージ
error: format argument must be a string literal
--> src/main.rs:11:34
|
11 | Err(e) => panic!(e),
| ^
|
help: you might be missing a string literal to format with
|
11 | Err(e) => panic!("{}", e),
| +++++
error: could not compile `main` (bin "main") due to 1 previous error
ソースコード
pub mod io {
use std::io::{BufRead, ErrorKind};
use std::str::{self, FromStr};
pub fn scan<R: BufRead, T: FromStr>(r: &mut R) -> T {
let mut tmp = Vec::new();
loop {
let buf = match r.fill_buf() {
Ok(buf) => buf,
Err(e) if e.kind() == ErrorKind::Interrupted => continue,
Err(e) => panic!(e),
};
let (done, used, mut buf) = {
match buf.iter().position(u8::is_ascii_whitespace) {
Some(i) => (i > 0 || tmp.len() > 0, i + 1, &buf[..i]),
None => (buf.is_empty(), buf.len(), buf),
}
};
if done {
if tmp.len() > 0 {
tmp.extend_from_slice(buf);
buf = &tmp;
}
let res = str::from_utf8(buf).unwrap().parse();
r.consume(used);
return res.ok().unwrap();
}
tmp.extend_from_slice(buf);
r.consume(used);
}
}
#[macro_export]
macro_rules! scan {
($r:expr, [$t:tt; $n:expr]) => {
(0..$n).map(|_| scan!($r, $t)).collect::<Vec<_>>()
};
($r:expr, [$t:tt]) => {
scan!($r, [$t; scan!($r, usize)])
};
($r:expr, ($($t:tt),*)) => {
($(scan!($r, $t)),*)
};
($r:expr, Usize1) => {
scan!($r, usize) - 1
};
($r:expr, Bytes) => {
scan!($r, String).into_bytes()
};
($r:expr, $t:ty) => {
io::scan::<_, $t>($r)
};
}
#[macro_export]
macro_rules! input {
($r:expr, $($($v:ident)* : $t:tt),* $(,)?) => {
$(let $($v)* = scan!($r, $t);)*
};
}
}
fn run<R: std::io::BufRead, W: std::io::Write>(reader: &mut R, writer: &mut W) {
input! {
reader,
a: u32, b: u32,
}
writeln!(writer, "{}", match (a, b) {
(2, 4) => "Yes",
(4, 2) => "Yes",
(a, b) if a == b => "Yes",
_ => "No",
}).ok();
}
fn main() {
let (stdin, stdout) = (std::io::stdin(), std::io::stdout());
let ref mut reader = std::io::BufReader::new(stdin.lock());
let ref mut writer = std::io::BufWriter::new(stdout.lock());
run(reader, writer);
}
Strorkis