結果
| 問題 |
No.1088 A+B Problem
|
| ユーザー |
|
| 提出日時 | 2020-07-05 20:23:37 |
| 言語 | Rust (1.83.0 + proconio) |
| 結果 |
AC
|
| 実行時間 | 1 ms / 2,000 ms |
| コード長 | 2,351 bytes |
| コンパイル時間 | 21,284 ms |
| コンパイル使用メモリ | 380,200 KB |
| 実行使用メモリ | 6,944 KB |
| 最終ジャッジ日時 | 2024-09-22 20:37:55 |
| 合計ジャッジ時間 | 15,121 ms |
|
ジャッジサーバーID (参考情報) |
judge3 / judge4 |
(要ログイン)
| ファイルパターン | 結果 |
|---|---|
| sample | AC * 2 |
| other | AC * 10 |
ソースコード
// macro_input
#[allow(unused_macros)]
macro_rules! rin {
( $( $rep:tt )* ) => {
let stdin = std::io::stdin();
let mut bytes = std::io::Read::bytes(std::io::BufReader::new(stdin.lock()));
let mut buf = move || -> String {
bytes
.by_ref()
.map(|r|r.unwrap() as char)
.skip_while(|c|c.is_whitespace())
.take_while(|c|!c.is_whitespace())
.collect()
};
rin_parse!{buf, $($rep)*}
};
}
#[allow(unused_macros)]
macro_rules! rin_parse {
( $buf:expr ) => {};
( $buf:expr, ) => {};
( $buf:expr, $type:tt : $var:tt, $($r:tt)* ) => {
rin_read!($buf, $type, $var, false);
rin_parse!($buf, $($r)*);
};
( $buf:expr, mut $type:tt : $var:tt, $($r:tt)* ) => {
rin_read!($buf, $type, $var, false);
rin_parse!($buf, $($r)*);
};
}
#[allow(unused_macros)]
macro_rules! rin_read {
( $buf:expr, $type:tt, $var:ident, false ) => {
let $var = read_value!($buf, $type);
};
( $buf:expr, $type:tt, [$var:ident, $($r:tt)*], false ) => {
rin_read!($buf, $type, $var, false);
rin_read!($buf, $type, $($r)*, false);
};
( $buf:expr, $type:tt, $var:ident, true ) => {
let mut $var = read_value!($buf, type);
};
( $buf:expr, $type:tt, [$var:ident, $($r:tt)*], true ) => {
rin_read!($buf, $type, $var);
rin_read!($buf, $type, $($r)*);
};
}
#[allow(unused_macros)]
macro_rules! read_value {
( $next:expr, ( $($t:tt),* ) ) => {
( $(read_value!($next, $t)),* )
};
( $next:expr, [ $t:tt ; [$len:expr, $($r:expr)*] ] ) => {
(0..$len).map(|_| read_value!($next, [$t; $($r)*])).collect::<Vec<_>>()
};
( $next:expr, [ $t:tt ; $len:expr ] ) => {
(0..$len).map(|_| read_value!($next, $t)).collect::<Vec<_>>()
};
( $next:expr, chars ) => {
read_value!($next, String).chars().collect::<Vec<char>>()
};
( $next:expr, usize1 ) => {
read_value!($next, usize) - 1
};
( $next:expr, $t:ty ) => {
$next().parse::<$t>().expect("Parse error")
};
}
// end macro
fn solve() {
rin! {
i32 : [a, b],
}
println!("{}", a + b);
}
fn main() {
let t = 1;
// rin!( usize : t, );
for _ in 0..t { solve(); }
}