M = 2000001; m = 10**9+7 ; p = int(input()) b = [0]*M b[4] = 1 for i in range(5,M) : b[i]=(2*p*b[i-1]+(2-p*p)*b[i-2]-2*p*b[i-3]-b[i-4])%m q = int(input()) for i in range(q) : x = int(input()) print((b[x]+m)%m)