結果
問題 |
No.1109 調の判定
|
ユーザー |
|
提出日時 | 2020-07-11 17:00:15 |
言語 | Rust (1.83.0 + proconio) |
結果 |
AC
|
実行時間 | 1 ms / 2,000 ms |
コード長 | 629 bytes |
コンパイル時間 | 19,734 ms |
コンパイル使用メモリ | 395,448 KB |
実行使用メモリ | 5,248 KB |
最終ジャッジ日時 | 2024-10-13 05:49:10 |
合計ジャッジ時間 | 15,640 ms |
ジャッジサーバーID (参考情報) |
judge4 / judge3 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
sample | AC * 3 |
other | AC * 43 |
ソースコード
fn main() { let mut n = String::new(); std::io::stdin().read_line(&mut n).ok(); let n: usize = n.trim().parse().unwrap(); let mut t = String::new(); std::io::stdin().read_line(&mut t).ok(); let t: Vec<usize> = t.trim().split_whitespace().map(|s| s.parse::<usize>().unwrap() + 12usize).collect(); let melody: Vec<usize> = vec![0,2,4,5,7,9,11]; let result: Vec<usize> = (0..12) .filter(|i| n == t.iter().filter(|&v| melody.contains(&((v - i) % 12))).count()) .collect(); if result.len() == 1 { println!("{}", result[0]); } else { println!("{}", -1); } }