結果
問題 | No.2972 確率的素数判定 |
ユーザー |
|
提出日時 | 2024-12-18 22:43:09 |
言語 | Rust (1.83.0 + proconio) |
結果 |
AC
|
実行時間 | 164 ms / 2,000 ms |
コード長 | 3,517 bytes |
コンパイル時間 | 14,151 ms |
コンパイル使用メモリ | 401,612 KB |
実行使用メモリ | 6,820 KB |
最終ジャッジ日時 | 2024-12-18 22:43:58 |
合計ジャッジ時間 | 17,490 ms |
ジャッジサーバーID (参考情報) |
judge5 / judge3 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
other | AC * 20 |
ソースコード
use proconio::input;fn main() {input! {t:usize,npq:[(usize,usize,usize);t],}const N_MAX: usize = 100000;let ps = eratosthenes_sieve(N_MAX);let mut cnts = vec![0; N_MAX + 1];for &p in ps.iter() {cnts[p] += 1;}for i in 0..N_MAX {cnts[i + 1] += cnts[i];}for &(n, p, q) in npq.iter() {let cnt_prime = cnts[n];let ans = (cnt_prime as f64 / n as f64) * (p as f64 / 100.0)/ ((cnt_prime as f64 / n as f64) * (p as f64 / 100.0)+ ((n - cnt_prime) as f64 / n as f64) * ((100 - q) as f64 / 100.0));println!("{}", ans);}}use math::eratosthenes_sieve;mod math {#[allow(dead_code)]pub fn pow(mut n: usize, mut e: usize, m: usize) -> usize {let mut res = 1;n %= m;while 0 < e {if e & 1 != 0 {res *= n;res %= m;}n *= n;n %= m;e >>= 1;}res}#[allow(dead_code)]pub fn gcd(a: usize, b: usize) -> usize {if b == 0 {a} else {gcd(b, a % b)}}#[allow(dead_code)]pub fn lcm(a: usize, b: usize) -> usize {a / gcd(a, b) * b}#[allow(dead_code)]pub fn prime_factor(mut n: usize) -> std::collections::HashMap<usize, usize> {let mut pfacs = std::collections::HashMap::new();for d in 2.. {if d * d > n {break;}while n % d == 0 {*pfacs.entry(d).or_insert(0) += 1;n /= d;}}if n != 1 {*pfacs.entry(n).or_insert(0) += 1;}pfacs}#[allow(dead_code)]pub fn divisors(n: usize) -> Vec<usize> {let mut divs = vec![];for d in (1..).take_while(|&d| d * d <= n) {if n % d == 0 {divs.push(d);if n / d != d {divs.push(n / d);}}}divs}#[allow(dead_code)]pub fn eratosthenes_sieve(n: usize) -> Vec<usize> {let mut is_primes = vec![true; n + 1];is_primes[0] = false;is_primes[1] = false;let mut primes = vec![];for i in 2..=n {if !is_primes[i] {continue;}for j in (2 * i..=n).step_by(i) {is_primes[j] = false;}}for (val, is_prime) in is_primes.into_iter().enumerate() {if is_prime {primes.push(val);}}primes}#[allow(dead_code)]pub fn base_n(mut base10: usize, base: usize, len: usize) -> Vec<usize> {let mut base_n = vec![];for _ in 0..len {base_n.push(base10 % base);base10 /= base;}base_n.reverse();base_n}#[allow(dead_code)]pub fn div_floor(mut a: i64, mut b: i64) -> i64 {if b < 0 {a = -a;b = -b;}if a >= 0 {a / b} else {(a + 1) / b - 1}}#[allow(dead_code)]pub fn div_ceil(mut a: i64, mut b: i64) -> i64 {if b < 0 {a = -a;b = -b;}if a > 0 {(a - 1) / b + 1} else {a / b}}}