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%M))
a=p(n,n,M)-a
a*=p(n-1,M-2,M)
P(a%M)