#include #define syosu(x) fixed< P; typedef pair pdd; typedef pair pll; typedef vector vi; typedef vector vvi; typedef vector vd; typedef vector vvd; typedef vector vl; typedef vector vvl; typedef vector vs; typedef vector

vp; typedef vector vvp; typedef vector vpll; typedef pair pip; typedef vector vip; const int inf=1<<30; const ll INF=1ll<<60; const double pi=acos(-1); const double eps=1e-9; const ll mod=1e9+7; const int dx[4]={0,1,0,-1},dy[4]={1,0,-1,0}; const int M=1000005; ll dp[M][4],n; int main(){ cin>>n; for(int i=1;i<=M;i++){ if(i<=3) dp[i][i]++; for(int j=1;j<=3;j++) for(int k=1;k<=3;k++) if(j!=k&&i>j) (dp[i][j]+=dp[i-j][k])%=mod; } cout<<(dp[n][1]+dp[n][2]+dp[n][3])%mod<