N,M=map(int,input().split())
mod=M
dp= [[[0 for k in range(N**2+1)] for j in range(N)]for i in range(N)]
for i in range(N):
  for j in range(N):
    dp[i][j][0]=1
for i in range(1,N):
  for j in range(N):
    #0~iok,j以下、和がkになる者
    for k in range(1,N**2+1):
      if j!=0:
        dp[i][j][k]+=dp[i][j-1][k]#全てj-1以下の時
        dp[i][j][k]%=mod
      if i!=0 and k>=j and j<=i:
        dp[i][j][k]+=dp[i-1][j][k-j]#jが含まれる。
        dp[i][j][k]%=mod
for i in range(N**2+1):
  print(dp[N-1][N-1][i])