不能连续三天相等,而每一次又有三种选择。设f[i][j] (j=0/1/2)为第j天选择第i 种的方案总数。
f[0][i]=f[1][i-1]+f[2][i-1]+f[1][i-2]+f[2][i-2]
f[1][i]=f[0][i-1]+f[2][i-1]+f[0][i-2]+f[2][i-2]
f[2][i]=f[1][i-1]+f[0][i-1]+f[1][i-2]+f[0][i-2]
f[i]=f[i-1]*2+f[i-2]*2
#include <bits/stdc++.h> #define size 100100 const int MOD=1e9+7; using namespace std; long long dp[size],n,m; int main(){ dp[1]=3,dp[2]=9; for (int i=3;i<size;i++){ dp[i]=(dp[i-1]*2%MOD+dp[i-2]*2%MOD)%MOD; } scanf("%lld",&m); while (m--){ scanf("%lld",&n); printf("%lld\n",dp[n]); } system("pause"); return 0; }