N,K,L=map(int,input().split()) ANS=1 mod=10**9+7 def m(a,b): r=[[0]*len(b[0]) for i in range(len(a))] for i in range(len(a)): for k in range(len(b)): for j in range(len(b[0])): r[i][j]=(r[i][j]+a[i][k]*b[k][j])%mod return r def p(a,n): r=[[0]*len(a) for i in range(len(a))] b=[] for i in range(len(a)): r[i][i]=1 b.append(a[i][:]) l=n while l>0: if l&1: r=m(b,r) b=m(b,b) l>>=1 return r X=[[0]*N for i in range(N)] Y=[[0]*N for i in range(N)] for i in range(N): for j in range(L): Y[(i+j)%N][i]=1 X[0][-1]=1 Z=m(p(Y,K),X) for i in range(N): print(Z[i][-1])