結果
問題 |
No.300 平方数
|
ユーザー |
![]() |
提出日時 | 2018-06-08 14:37:07 |
言語 | C++14 (gcc 13.3.0 + boost 1.87.0) |
結果 |
AC
|
実行時間 | 12 ms / 1,000 ms |
コード長 | 1,132 bytes |
コンパイル時間 | 761 ms |
コンパイル使用メモリ | 86,628 KB |
実行使用メモリ | 6,944 KB |
最終ジャッジ日時 | 2024-06-30 10:39:38 |
合計ジャッジ時間 | 2,395 ms |
ジャッジサーバーID (参考情報) |
judge1 / judge2 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
sample | AC * 3 |
other | AC * 43 |
ソースコード
#include <algorithm> #include <cmath> #include <cstdio> #include <cstring> #include <deque> #include <iostream> #include <map> #include <queue> #include <set> #include <stack> #include <string> #include <utility> #include <vector> #define p(s) cout<<(s)<<endl #define REP(i,n,N) for(ll i=n;i<N;i++) #define RREP(i,n,N) for(ll i=N-1;i>=n;i--) #define CK(n,a,b) ((a)<=(n)&&(n)<(b)) #define F first #define S second typedef long long ll; using namespace std; const ll inf=1e9+7; ll X, Y; vector<pair<ll, ll>> prime_factor(ll n) { vector<pair<ll, ll>> vp; // iがsqrt(n)となるまで繰り返す for (ll i = 2; i*i <= n; i++) { if (n%i == 0) { // iが素因数 vp.emplace_back(i, 0); // 素因数の数を求める do { vp[vp.size() - 1].second++; n /= i; } while (n%i == 0); } } if (n != 1) vp.emplace_back(n, 1); return vp; } int main(){ Y=1; cin>>X; vector<pair<ll, ll>> pf = prime_factor(X); REP(i,0,pf.size()){ if(pf[i].second%2) Y*=pf[i].first; } p(Y); return 0; }