結果
問題 | No.212 素数サイコロと合成数サイコロ (2) |
ユーザー | tonyu0 |
提出日時 | 2020-04-26 17:32:41 |
言語 | Rust (1.77.0 + proconio) |
結果 |
AC
|
実行時間 | 32 ms / 5,000 ms |
コード長 | 955 bytes |
コンパイル時間 | 9,701 ms |
コンパイル使用メモリ | 401,528 KB |
実行使用メモリ | 6,820 KB |
最終ジャッジ日時 | 2024-11-17 14:41:05 |
合計ジャッジ時間 | 10,558 ms |
ジャッジサーバーID (参考情報) |
judge5 / judge4 |
(要ログイン)
テストケース
テストケース表示入力 | 結果 | 実行時間 実行使用メモリ |
---|---|---|
testcase_00 | AC | 1 ms
6,816 KB |
testcase_01 | AC | 1 ms
6,816 KB |
testcase_02 | AC | 1 ms
6,816 KB |
testcase_03 | AC | 1 ms
6,820 KB |
testcase_04 | AC | 1 ms
6,820 KB |
testcase_05 | AC | 32 ms
6,816 KB |
testcase_06 | AC | 6 ms
6,820 KB |
testcase_07 | AC | 6 ms
6,816 KB |
testcase_08 | AC | 1 ms
6,820 KB |
testcase_09 | AC | 1 ms
6,820 KB |
ソースコード
use std::io::*; fn rec(sai: &[usize], res: &mut Vec<usize>, v: usize, c: usize, n: usize) { if c == n { res.push(v); return; } for i in 0..sai.len() { rec(&sai, res, v * sai[i], c + 1, n); } } fn main() { let mut s: String = String::new(); std::io::stdin().read_to_string(&mut s).ok(); let mut itr = s.trim().split_whitespace(); let p: usize = itr.next().unwrap().parse().unwrap(); let c: usize = itr.next().unwrap().parse().unwrap(); let sai1: Vec<usize> = [2, 3, 5, 7, 11, 13].to_vec(); let sai2: Vec<usize> = [4, 6, 8, 9, 10, 12].to_vec(); let mut ans = 0; let all = 6usize.pow((p + c) as u32); let mut a = Vec::new(); let mut b = Vec::new(); rec(&sai1, &mut a, 1, 0, p); rec(&sai2, &mut b, 1, 0, c); for i in 0..a.len() { for j in 0..b.len() { ans += a[i] * b[j]; } } println!("{:.10}", ans as f64 / all as f64); }