#include #include #include #include #include #include #include #include #include #include using namespace std; #define int long long int MOD; int zero; int one; int two; int add(int a, int b) { while (b != zero) { int c = (a & b) << one; a ^= b; b = c; } return a; } int sub(int a, int b) { return add(a, add(~b, one)); } int mul(int a, int b) { int c = zero; while (b != zero) { if (b & one) c = add(c, a); b >>= one; a <<= one; } return c; } int msb(int a) { int c = zero; while (a != zero) { a >>= one; c = add(c, one); } return c; } int mydiv(int a, int b) { int q = zero; int c = sub(msb(a), msb(b)); for (; c >= zero; c = sub(c, one)) { int d = sub(a, b << c); if (d >= zero) { a = d; q |= one << c; } } return a; } void initmod() { int ten = mul(two, add(two, add(two, one))); MOD = one; MOD = mul(MOD, ten); MOD = mul(MOD, ten); MOD = mul(MOD, ten); MOD = mul(MOD, ten); MOD = mul(MOD, ten); MOD = mul(MOD, ten); MOD = mul(MOD, ten); MOD = mul(MOD, ten); MOD = mul(MOD, ten); MOD = add(MOD, sub(ten, add(two, one))); } using Mat = vector >; Mat matmul(Mat a, Mat b) { Mat res(two, vector(two, zero)); res[zero][zero] = add(mydiv(mul(a[zero][zero], b[zero][zero]), MOD), mydiv(mul(a[zero][one], b[one][zero]), MOD)); res[one][zero] = add(mydiv(mul(a[one][zero], b[zero][zero]), MOD), mydiv(mul(a[one][one], b[one][zero]), MOD)); res[zero][one] = add(mydiv(mul(a[zero][zero], b[zero][one]), MOD), mydiv(mul(a[zero][one], b[one][one]), MOD)); res[one][one] = add(mydiv(mul(a[one][zero], b[zero][one]), MOD), mydiv(mul(a[one][one], b[one][one]), MOD)); return res; } Mat matpow(Mat a, int b) { if (b == one)return a; if ((b & one) == zero) { return matpow(matmul(a, a), b >> one); } else { return matmul(matpow(matmul(a, a), b >> one), a); } } signed main() { int N; cin >> N; zero = N^N; one = abs(~zero); two = add(one, one); initmod(); vector A(N); Mat k(two, vector(two)); k[zero][zero] = one; k[zero][one] = one; k[one][zero] = one; k[one][one] = zero; for (int i = zero; i < N; i = add(i, one)) { cin >> A[i]; Mat x = matpow(k, A[i]); cout << mydiv(add(x[one][zero], mul(x[one][one], two)), MOD) << endl; } }