結果

問題 No.3296 81-like number
ユーザー tau1235
提出日時 2025-10-05 14:29:46
言語 C++23
(gcc 13.3.0 + boost 1.87.0)
結果
AC  
実行時間 11 ms / 2,000 ms
コード長 515 bytes
コンパイル時間 2,661 ms
コンパイル使用メモリ 279,048 KB
実行使用メモリ 7,716 KB
最終ジャッジ日時 2025-10-05 14:30:19
合計ジャッジ時間 3,738 ms
ジャッジサーバーID
(参考情報)
judge5 / judge4
このコードへのチャレンジ
(要ログイン)
ファイルパターン 結果
sample AC * 3
other AC * 15
権限があれば一括ダウンロードができます

ソースコード

diff #

#include<bits/stdc++.h>
using namespace std;

vector<int> sieve(int n){
  vector<int> prime;
  vector<bool> isprime(n+1,true);
  isprime[1]=false;
  for (int i=2;i<=n;i++){
    if (!isprime[i]) continue;
    prime.push_back(i);
    for (int j=i*2;j<=n;j+=i){
      isprime[j]=false;
    }
  }
  return prime;
}

int main(){
  using ll=long long;
  ll n;
  cin>>n;
  auto ps=sieve(1e6);
  ll ans=0;
  for (ll p:ps){
    ll prod=p*p;
    while (prod<=n){
      ans+=prod;
      prod*=p;
    }
  }
  cout<<ans<<endl;
}
0