結果
問題 |
No.719 Coprime
|
ユーザー |
![]() |
提出日時 | 2018-07-27 23:47:57 |
言語 | Rust (1.83.0 + proconio) |
結果 |
WA
|
実行時間 | - |
コード長 | 764 bytes |
コンパイル時間 | 25,692 ms |
コンパイル使用メモリ | 378,552 KB |
実行使用メモリ | 6,948 KB |
最終ジャッジ日時 | 2024-07-05 06:02:16 |
合計ジャッジ時間 | 14,079 ms |
ジャッジサーバーID (参考情報) |
judge2 / judge5 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
other | WA * 61 |
ソースコード
use std::io::{stdin, Read}; fn main() { let mut buf = String::new(); stdin().read_to_string(&mut buf).unwrap(); let mut tok = buf.split_whitespace(); let mut get = || tok.next().unwrap(); macro_rules! get { ($t:ty) => (get().parse::<$t>().unwrap()); () => (get!(usize)); } let n = get!(); let mut xs = vec![false; n + 1]; let mut ys = vec![]; for i in 2..xs.len() { if xs[i] { continue; } ys.push(i); for j in 2..xs.len() { if i * j >= xs.len() { break; } xs[i*j] = true; } } let mut ans: usize = ys.iter().sum(); if let Some(s) = ys.iter().filter(|&y| y * 2 <= n).last() { ans += s; } println!("{}", ans - 2); }