結果
問題 |
No.847 Divisors of Power
|
ユーザー |
|
提出日時 | 2020-05-05 06:32:54 |
言語 | C++17 (gcc 13.3.0 + boost 1.87.0) |
結果 |
AC
|
実行時間 | 6 ms / 2,000 ms |
コード長 | 778 bytes |
コンパイル時間 | 2,155 ms |
コンパイル使用メモリ | 200,816 KB |
最終ジャッジ日時 | 2025-01-10 06:42:46 |
ジャッジサーバーID (参考情報) |
judge3 / judge2 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
sample | AC * 4 |
other | AC * 26 |
ソースコード
#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; } lint k,m; map<lint,int> pf; map<lint,int>::iterator it; int dfs(lint x){ if(it==pf.end()) return 1; lint p=it->first,q=k*it->second; int res=0; rep(i,q+1){ ++it; res+=dfs(x); --it; x*=p; if(x>m) break; } return res; } int main(){ lint n; cin>>n>>k>>m; pf=prime_factorize(n); it=pf.begin(); cout<<dfs(1)<<'\n'; return 0; }