結果
問題 | No.1514 Squared Matching |
ユーザー |
👑 ![]() |
提出日時 | 2021-05-22 04:14:47 |
言語 | C++14 (gcc 13.3.0 + boost 1.87.0) |
結果 |
AC
|
実行時間 | 776 ms / 4,000 ms |
コード長 | 532 bytes |
コンパイル時間 | 669 ms |
コンパイル使用メモリ | 71,104 KB |
実行使用メモリ | 394,016 KB |
最終ジャッジ日時 | 2024-10-10 10:37:39 |
合計ジャッジ時間 | 14,280 ms |
ジャッジサーバーID (参考情報) |
judge4 / judge2 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
other | AC * 26 |
ソースコード
#include<iostream> #include<vector> using namespace std; int main(){ int N; cin >> N; vector<int> S(N+1,0); S[1]=1; vector<int> U(N+1); for (int i=0; i<=N; i++) U[i]=i; int j,k; for (int i=2; i*i<=N; i++){ j=i*i; k=i*i; S[j]=1; while (j<=N){ while (U[j]%k==0) U[j]/=k; j+=k; } } for (int i=1; i<=N; i++) S[i]+=S[i-1]; long long X=0; for (int i=1; i<=N; i++) X+=S[N/U[i]]; cout << X << endl; }