結果

問題 No.24 数当てゲーム
ユーザー cra77756176cra77756176
提出日時 2022-11-18 01:14:03
言語 Rust
(1.77.0)
結果
AC  
実行時間 1 ms / 5,000 ms
コード長 802 bytes
コンパイル時間 2,019 ms
コンパイル使用メモリ 191,440 KB
実行使用メモリ 4,348 KB
最終ジャッジ日時 2023-10-19 15:22:16
合計ジャッジ時間 2,613 ms
ジャッジサーバーID
(参考情報)
judge13 / judge11
このコードへのチャレンジ
(要ログイン)

テストケース

テストケース表示
入力 結果 実行時間
実行使用メモリ
testcase_00 AC 1 ms
4,348 KB
testcase_01 AC 1 ms
4,348 KB
testcase_02 AC 1 ms
4,348 KB
testcase_03 AC 1 ms
4,348 KB
testcase_04 AC 1 ms
4,348 KB
testcase_05 AC 1 ms
4,348 KB
testcase_06 AC 1 ms
4,348 KB
testcase_07 AC 1 ms
4,348 KB
testcase_08 AC 1 ms
4,348 KB
testcase_09 AC 1 ms
4,348 KB
権限があれば一括ダウンロードができます

ソースコード

diff #

use std::{
    collections::HashSet,
    io::{self, BufRead},
};

fn main() {
    let input = io::stdin()
        .lock()
        .lines()
        .map(|l| {
            l.unwrap()
                .split(' ')
                .map(std::string::ToString::to_string)
                .collect::<Vec<_>>()
        })
        .collect::<Vec<_>>();

    let mut possible = (0..=9).collect::<HashSet<_>>();

    input[1..].iter().for_each(|l| {
        let numbers = l[..4]
            .iter()
            .map(|n| n.parse::<usize>().unwrap())
            .collect::<HashSet<_>>();

        if l[4] == "YES" {
            possible.retain(|n| numbers.contains(n));
        } else {
            possible.retain(|n| !numbers.contains(n));
        }
    });

    println!("{}", possible.iter().next().unwrap());
}
0