結果
| 問題 |
No.732 3PrimeCounting
|
| ユーザー |
|
| 提出日時 | 2018-09-07 23:06:56 |
| 言語 | C++14 (gcc 13.3.0 + boost 1.87.0) |
| 結果 |
TLE
|
| 実行時間 | - |
| コード長 | 1,002 bytes |
| コンパイル時間 | 811 ms |
| コンパイル使用メモリ | 86,404 KB |
| 実行使用メモリ | 10,496 KB |
| 最終ジャッジ日時 | 2024-11-29 19:19:01 |
| 合計ジャッジ時間 | 152,901 ms |
|
ジャッジサーバーID (参考情報) |
judge3 / judge4 |
(要ログイン)
| ファイルパターン | 結果 |
|---|---|
| other | AC * 57 TLE * 32 |
ソースコード
#include <iostream>
#include <math.h>
#include <vector>
#include <map>
using namespace std;
typedef long long LL;
int IsPrime (int n)
{
int i;
if (n < 2){
return 0;
}else if (n == 2){
return 1;
}
if (n % 2 == 0){
return 0;
}
double sqrtNum = sqrt((double)n);
for (i = 3; i <= sqrtNum; i += 2){
if (n % i == 0 ){
return 0;
}
}
return 1;
}
int main(int argc, char* argv[])
{
int N;
cin>>N;
int i,j,k;
LL ans=0;
map<int,int> myMap;
map<int,int>::iterator mit;
for (i=3;i<=300000;i+=2){
if (IsPrime(i)){
myMap[i]=1;
}
}
vector<int> Prime;
for (i=3;i<=N;i+=2){
mit=myMap.find(i);
if (mit!=myMap.end()){
Prime.push_back(i);
}
}
int PrimeNum=Prime.size();
for (i=0;i<PrimeNum-2;i++){
for (j=i+1;j<PrimeNum-1;j++){
for (k=j+1;k<PrimeNum;k++){
int x=Prime[i]+Prime[j]+Prime[k];
if (x%2==1){
mit=myMap.find(x);
if (mit!=myMap.end()){
ans++;
}
}
}
}
}
cout<<ans<<endl;
return 0;
}