結果
問題 | No.24 数当てゲーム |
ユーザー |
|
提出日時 | 2022-01-09 07:43:26 |
言語 | Rust (1.83.0 + proconio) |
結果 |
AC
|
実行時間 | 1 ms / 5,000 ms |
コード長 | 1,884 bytes |
コンパイル時間 | 13,186 ms |
コンパイル使用メモリ | 388,908 KB |
実行使用メモリ | 6,820 KB |
最終ジャッジ日時 | 2024-11-14 10:11:17 |
合計ジャッジ時間 | 14,126 ms |
ジャッジサーバーID (参考情報) |
judge4 / judge1 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
other | AC * 10 |
ソースコード
#[macro_export]macro_rules! setup {{ mut $input:ident: SplitWhitespace $(,)? } => {use std::io::Read;let mut buf = String::new();std::io::stdin().read_to_string(&mut buf).unwrap();let mut $input = buf.split_whitespace();};}#[macro_export]macro_rules! parse_next {($str_iter:expr) => {$str_iter.next().unwrap().parse().unwrap()};}use std::collections::HashSet;fn main() {setup! { mut input: SplitWhitespace };let n: usize = parse_next!(input);let mut a: Vec<usize> = vec![];let mut b: Vec<usize> = vec![];let mut c: Vec<usize> = vec![];let mut d: Vec<usize> = vec![];let mut r: Vec<String> = vec![];(0..n).for_each(|_| {a.push(parse_next!(input));b.push(parse_next!(input));c.push(parse_next!(input));d.push(parse_next!(input));r.push(parse_next!(input));});let mut nums = HashSet::new();(0..=9).for_each(|num| {nums.insert(num);});for i in 0..n {match r[i].as_str() {"YES" => {for num in 0..=9 {if num == a[i] {continue;}if num == b[i] {continue;}if num == c[i] {continue;}if num == d[i] {continue;}nums.remove(&num);}}"NO" => {nums.remove(&a[i]);nums.remove(&b[i]);nums.remove(&c[i]);nums.remove(&d[i]);}_ => unreachable!(),}}let ans = nums.iter().nth(0).unwrap().clone();println!("{}", ans);}