結果
| 問題 | No.24 数当てゲーム | 
| コンテスト | |
| ユーザー |  ta60143 | 
| 提出日時 | 2019-02-14 17:27:40 | 
| 言語 | Rust (1.83.0 + proconio) | 
| 結果 | 
                                AC
                                 
                             | 
| 実行時間 | 1 ms / 5,000 ms | 
| コード長 | 1,467 bytes | 
| コンパイル時間 | 13,941 ms | 
| コンパイル使用メモリ | 378,444 KB | 
| 実行使用メモリ | 5,376 KB | 
| 最終ジャッジ日時 | 2024-09-13 11:28:47 | 
| 合計ジャッジ時間 | 14,701 ms | 
| ジャッジサーバーID (参考情報) | judge2 / judge4 | 
(要ログイン)
| ファイルパターン | 結果 | 
|---|---|
| other | AC * 10 | 
ソースコード
fn main() {
    let mut mat: Vec<Vec<String>> = read_mat(read::<u32>());
    for row in &mut mat {
        if row[4] == String::from("YES") {
            row[4] = String::from("1");
        }
        else if row[4] == String::from("NO") {
            row[4] = String::from("0");
        }
    }
    let mat: Vec<Vec<u32>> = mat.into_iter().map(|row| {
        row.into_iter().map(|e| {
            e.parse::<u32>().ok().unwrap()
        }).collect()
    }).collect();
    let mut counter = [0i32; 10];
    for row in mat {
        if row[4] == 1 {
            for i in 0..4 {
                counter[row[i] as usize] += 1;
            }
        }
        else {
            for i in 0..4 {
                counter[row[i] as usize] -= 1;
            }
        }
    }
    let mut i = 0;
    for (j, &value) in counter.iter().enumerate() {
        if value > counter[i] {
            i = j;
        }
    }
    println!("{}", i);
}
fn read<T: std::str::FromStr>() -> T {
    let mut s = String::new();
    std::io::stdin().read_line(&mut s).ok();
    s.trim().parse().ok().unwrap()
}
fn read_vec<T: std::str::FromStr>() -> Vec<T> {
    let mut s = String::new();
    std::io::stdin().read_line(&mut s).ok();
    s.trim().split_whitespace()
        .map(|e| e.parse().ok().unwrap()).collect()
}
fn read_mat<T: std::str::FromStr>(row: u32) -> Vec<Vec<T>> {
    let mut vec = Vec::new();
    for _i in 0..row {
        vec.push(read_vec::<T>());
    }
    vec
}
            
            
            
        