1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54
| #include <bits/stdc++.h> using namespace std; #define rep(i,a,n) for(int i=a;i<n;i++) #define repd(i,a,n) for(int i=n-1;i>=a;i--) #define CRL(a,x) memset(a,x,sizeof(a)) typedef long long ll; const ll mod= 1e9+7;
struct Mat{ ll data[6][6]; Mat(){CRL(data,0);} Mat operator* (Mat &a) const{ Mat c; rep(i,0,6) rep(j,0,6) rep(k,0,6) c.data[i][j]=(c.data[i][j]+data[i][k]*a.data[k][j]%mod)%mod; return c; } };
Mat Mat_qpow(Mat a,ll n){ Mat tem;rep(i,0,6) tem.data[i][i]=1; while(n){ if(n&1) tem=tem*a; a=a*a; n>>=1; } return tem; }
ll M[6][6] = { {1, 1, 1, 1, 1, 1}, {1, 0, 0, 0, 0, 0}, {0, 0, 1, 3, 3, 1}, {0, 0, 0, 1, 2, 1}, {0, 0, 0, 0, 1, 1}, {0, 0, 0, 0, 0, 1} };
int main() { Mat a,ans; memcpy(a.data,M,sizeof(M)); int t;ll n; scanf("%d",&t); while(t--){ scanf("%lld",&n); if(n<2LL) {printf("%lld\n",n);continue;} ans=Mat_qpow(a,n-1); printf("%lld\n",(ans.data[0][0]+ans.data[0][2]*8%mod+ans.data[0][3]*4%mod+ans.data[0][4]*2%mod+ans.data[0][5])%mod); } return 0; }
|