結果
問題 |
No.847 Divisors of Power
|
ユーザー |
|
提出日時 | 2020-05-05 06:27:54 |
言語 | C++17 (gcc 13.3.0 + boost 1.87.0) |
結果 |
WA
|
実行時間 | - |
コード長 | 815 bytes |
コンパイル時間 | 2,731 ms |
コンパイル使用メモリ | 200,816 KB |
最終ジャッジ日時 | 2025-01-10 06:42:26 |
ジャッジサーバーID (参考情報) |
judge3 / judge3 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
sample | AC * 4 |
other | AC * 25 WA * 1 |
ソースコード
#include <bits/stdc++.h> #define rep(i,n) for(int i=0;i<(n);i++) using namespace std; using lint=long long; map<long long,int> prime_factorize(long long a){ map<long long,int> res; if(a%2==0){ int cnt=0; do{ cnt++; a/=2; }while(a%2==0); res.emplace(2,cnt); } for(long long p=3;p*p<=a;p+=2) if(a%p==0) { int cnt=0; do{ cnt++; a/=p; }while(a%p==0); res.emplace(p,cnt); } if(a>1) res.emplace(a,1); return res; } map<lint,int> pf; map<lint,int>::iterator it; int dfs(lint x,lint m){ if(it==pf.end()) return 1; lint p=it->first,q=it->second; lint res=0; rep(i,q+1){ ++it; res+=dfs(x,m); --it; x*=p; if(x>m) break; } return res; } int main(){ lint n,k,m; cin>>n>>k>>m; pf=prime_factorize(n); for(auto& q:pf) q.second*=k; it=pf.begin(); cout<<dfs(1,m)<<'\n'; return 0; }