結果
| 問題 |
No.843 Triple Primes
|
| コンテスト | |
| ユーザー |
QCFium
|
| 提出日時 | 2019-06-28 21:36:47 |
| 言語 | C++14 (gcc 13.3.0 + boost 1.87.0) |
| 結果 |
AC
|
| 実行時間 | 328 ms / 2,000 ms |
| コード長 | 642 bytes |
| コンパイル時間 | 1,500 ms |
| コンパイル使用メモリ | 173,656 KB |
| 実行使用メモリ | 7,552 KB |
| 最終ジャッジ日時 | 2024-09-19 13:51:36 |
| 合計ジャッジ時間 | 9,236 ms |
|
ジャッジサーバーID (参考情報) |
judge4 / judge1 |
(要ログイン)
| ファイルパターン | 結果 |
|---|---|
| sample | AC * 2 |
| other | AC * 42 |
ソースコード
#include <bits/stdc++.h>
int ri() {
int n;
scanf("%d", &n);
return n;
}
int is_prime[500001];
int main() {
int n = ri();
for (int i = 2; i <= 500000; i++) is_prime[i] = true;
for (int i = 2; i <= 500000; i++) {
if (!is_prime[i]) continue;
for (int j = 2; j * i <= 500000; j++)
is_prime[j * i] = false;
}
std::set<int64_t> primes;
for (int i = 2; i <= n; i++) if (is_prime[i]) primes.insert(i);
int res = 0;
for (auto i : primes) {
int64_t pow2 = (int64_t) i * i;
if (pow2 > 2 * n) continue;
for (auto j : primes) if (pow2 - j <= n && primes.count(pow2 - j)) res++;
}
std::cout << res << std::endl;
return 0;
}
QCFium