M,P,p=10**9+7,print,pow n,k,m=map(int,input().split()) a,y=0,1 for i in range(1,n+1): if k%i==0:a+=y*p(n,n-i,M) y*=n-i;y%M if m==1:exit(P(a)) a=p(n,n,M)-a a*=p(n-1,M-2,M) P(a%M)