N, M = map(int, input().split()) dp = [[[0 for i in range(N*N+1)]for j in range(N+1)]for k in range(2)] dp[0][0][0] = 1 for i in range(N): for j in range(min(N+1,i+2)): for k in range(min(N*N+1, (i+2)*(i+2))): f = (i+1)&1 g = 1-f dp[f][j][k] = 0 if 0 < j: dp[f][j][k] += dp[f][j-1][k] if j <= i and j <= k: dp[f][j][k] += dp[g][j][k-j] dp[f][j][k] %= M for i in range(N*N+1): print(dp[N%2][N][i])