#include #include using namespace std; const long long MOD = 998244353; long long dp[2][6010]; int main(){ int n,q;cin>>n>>q; vector A(n); for(int i = 0; n > i; i++){ cin>>A[i]; } dp[0][0] = 1; for(int i = 0; n > i; i++){ for(int j = 0; n > j; j++){ dp[1][j+1] = (dp[1][j+1]+dp[0][j])%MOD; dp[1][j] = (dp[1][j]+dp[0][j]*(A[i]-1))%MOD; } for(int j = 0; n >= j; j++){ dp[0][j] = dp[1][j]; dp[1][j] = 0; } } for(int i = 0; q > i; i++){ int x;cin>>x; cout << dp[0][x] << endl; } }