#include #define rep(i,n) for(int i=0;i<(n);i++) using namespace std; using lint=long long; map prime_factorize(long long a){ map 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 pf; map::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<