結果
問題 | No.2756 GCD Teleporter |
ユーザー | magurofly |
提出日時 | 2024-05-10 23:17:39 |
言語 | Rust (1.77.0 + proconio) |
結果 |
AC
|
実行時間 | 74 ms / 2,000 ms |
コード長 | 4,067 bytes |
コンパイル時間 | 13,674 ms |
コンパイル使用メモリ | 385,768 KB |
実行使用メモリ | 22,624 KB |
最終ジャッジ日時 | 2024-12-20 07:32:40 |
合計ジャッジ時間 | 16,719 ms |
ジャッジサーバーID (参考情報) |
judge5 / judge4 |
(要ログイン)
テストケース
テストケース表示入力 | 結果 | 実行時間 実行使用メモリ |
---|---|---|
testcase_00 | AC | 1 ms
6,820 KB |
testcase_01 | AC | 1 ms
6,816 KB |
testcase_02 | AC | 1 ms
6,820 KB |
testcase_03 | AC | 1 ms
6,820 KB |
testcase_04 | AC | 8 ms
6,820 KB |
testcase_05 | AC | 23 ms
9,108 KB |
testcase_06 | AC | 55 ms
18,064 KB |
testcase_07 | AC | 48 ms
15,280 KB |
testcase_08 | AC | 43 ms
14,380 KB |
testcase_09 | AC | 36 ms
12,900 KB |
testcase_10 | AC | 51 ms
16,812 KB |
testcase_11 | AC | 66 ms
20,220 KB |
testcase_12 | AC | 16 ms
7,452 KB |
testcase_13 | AC | 66 ms
21,336 KB |
testcase_14 | AC | 59 ms
19,896 KB |
testcase_15 | AC | 17 ms
7,588 KB |
testcase_16 | AC | 34 ms
12,652 KB |
testcase_17 | AC | 42 ms
14,580 KB |
testcase_18 | AC | 15 ms
7,324 KB |
testcase_19 | AC | 65 ms
21,556 KB |
testcase_20 | AC | 47 ms
17,868 KB |
testcase_21 | AC | 24 ms
10,368 KB |
testcase_22 | AC | 52 ms
17,948 KB |
testcase_23 | AC | 9 ms
6,820 KB |
testcase_24 | AC | 39 ms
14,800 KB |
testcase_25 | AC | 42 ms
15,512 KB |
testcase_26 | AC | 47 ms
17,284 KB |
testcase_27 | AC | 51 ms
18,088 KB |
testcase_28 | AC | 29 ms
11,392 KB |
testcase_29 | AC | 43 ms
15,104 KB |
testcase_30 | AC | 52 ms
18,944 KB |
testcase_31 | AC | 25 ms
9,984 KB |
testcase_32 | AC | 31 ms
16,576 KB |
testcase_33 | AC | 13 ms
8,320 KB |
testcase_34 | AC | 9 ms
6,816 KB |
testcase_35 | AC | 40 ms
16,900 KB |
testcase_36 | AC | 41 ms
16,516 KB |
testcase_37 | AC | 1 ms
6,816 KB |
testcase_38 | AC | 59 ms
18,212 KB |
testcase_39 | AC | 74 ms
22,624 KB |
コンパイルメッセージ
warning: variable `N` should have a snake case name --> src/main.rs:9:9 | 9 | N: usize, | ^ help: convert the identifier to snake case: `n` | = note: `#[warn(non_snake_case)]` on by default warning: variable `A` should have a snake case name --> src/main.rs:10:9 | 10 | A: [usize; N], | ^ help: convert the identifier to snake case: `a`
ソースコード
pub use __cargo_equip::prelude::*; use proconio::input; use std::collections::*; use acl_dsu::*; fn main() { input! { N: usize, A: [usize; N], } let max = *A.iter().max().unwrap(); let (_, sieve) = linear_sieve(max); let mut by_prime_factor = HashMap::new(); for i in 0 .. N { let mut n = A[i]; while n > 1 { let p = sieve[n]; while n % p == 0 { n /= p; } by_prime_factor.entry(p).or_insert_with(Vec::new).push(i); } } let mut dsu = Dsu::new(N); for (_, vertices) in &by_prime_factor { for i in 1 .. vertices.len() { dsu.merge(vertices[0], vertices[i]); } } // let mut min_prime_factor = vec![200000; N]; // let mut leaders = vec![]; // for v in 0 .. N { // let r = dsu.leader(v); // leaders.push(r); // let p = &mut min_prime_factor[r]; // let p0 = *p; // let q = sieve[A[v]]; // if q > 1 { // *p = p0.min(q); // } // } let min_prime_factors = dsu.groups().iter().map(|group| { let mut ans = 1_000_000_000; for &v in group { if A[v] != 1 { ans = ans.min(sieve[A[v]]); } } ans }).collect::<Vec<_>>(); // println!("{:?}", min_prime_factors); let n = min_prime_factors.len(); let mut ans = 2 * n; let p = *min_prime_factors.iter().min().unwrap(); ans = ans.min(p * (n - 1)); println!("{}", ans); } fn linear_sieve(limit: usize) -> (Vec<usize>, Vec<usize>) { let mut primes = vec![]; let mut table = vec![1; limit + 1]; for d in 2 ..= limit { if table[d] == 1 { table[d] = d; primes.push(d); } for &p in &primes { if p * d > limit || p > table[d] { break; } table[p * d] = p; } } (primes, table) } // The following code was expanded by `cargo-equip`. /// # Bundled libraries /// /// - `ac-library-rs-parted-dsu 0.1.0 (path+██████████████████████████████████████████████████████████████████████)` published in https://github.com/qryxip/ac-library-rs-parted licensed under `CC0-1.0` as `crate::__cargo_equip::crates::acl_dsu` #[cfg_attr(any(), rustfmt::skip)] #[allow(unused)] mod __cargo_equip { pub(crate) mod crates { pub mod acl_dsu {pub use self::dsu::*;mod dsu{pub struct Dsu{n:usize,parent_or_size:Vec<i32>,}impl Dsu{pub fn new(size:usize)->Self{Self{n:size,parent_or_size:vec![-1;size],}}pub fn merge(&mut self,a:usize,b:usize)->usize{assert!(a<self.n);assert!(b<self.n);let(mut x,mut y)=(self.leader(a),self.leader(b));if x==y{return x;}if-self.parent_or_size[x]< -self.parent_or_size[y]{std::mem::swap(&mut x,&mut y);}self.parent_or_size[x]+=self.parent_or_size[y];self.parent_or_size[y]=x as i32;x}pub fn same(&mut self,a:usize,b:usize)->bool{assert!(a<self.n);assert!(b<self.n);self.leader(a)==self.leader(b)}pub fn leader(&mut self,a:usize)->usize{assert!(a<self.n);if self.parent_or_size[a]<0{return a;}self.parent_or_size[a]=self.leader(self.parent_or_size[a]as usize)as i32;self.parent_or_size[a]as usize}pub fn size(&mut self,a:usize)->usize{assert!(a<self.n);let x=self.leader(a);-self.parent_or_size[x]as usize}pub fn groups(&mut self)->Vec<Vec<usize>>{let mut leader_buf=vec![0;self.n];let mut group_size=vec![0;self.n];for i in 0..self.n{leader_buf[i]=self.leader(i);group_size[leader_buf[i]]+=1;}let mut result=vec![Vec::new();self.n];for i in 0..self.n{result[i].reserve(group_size[i]);}for i in 0..self.n{result[leader_buf[i]].push(i);}result.into_iter().filter(|x|!x.is_empty()).collect::<Vec<Vec<usize>>>()}}}} } pub(crate) mod macros { pub mod acl_dsu {} } pub(crate) mod prelude {pub use crate::__cargo_equip::crates::*;} mod preludes { pub mod acl_dsu {} } }