#include using namespace std; int main(){ int N, M, C; cin >> N >> M >> C; vector A(N); for (int i = 0; i < N; i++){ cin >> A[i]; } int S = 0; vector> dp(1, vector(1, 0)); dp[0][0] = 1; for (int i = 0; i < N; i++){ vector> dp2(i + 2, vector(S + A[i] + 1, 0)); for (int j = 0; j <= i; j++){ for (int k = 0; k <= S; k++){ dp2[j][k] += dp[j][k]; if (dp2[j][k] >= M){ dp2[j][k] -= M; } dp2[j + 1][k + A[i]] += dp[j][k]; } } S += A[i]; swap(dp, dp2); } for (int i = 1; i <= S; i++){ cout << dp[C][i]; if (i < S){ cout << ' '; } } cout << endl; }